14 phpMyAdmin 2.11.9.5 Documentation
17 * SourceForge phpMyAdmin project page
18 * Official phpMyAdmin wiki
20 + Version history: ChangeLog
21 + General notes: README
23 * Documentation version: $Id: Documentation.html 12317 2009-03-24 21:04:18Z
29 + You need PHP 4.2.0 or newer, with session support (see FAQ 1.31)
30 + You need GD2 support in PHP to display inline thumbnails of JPEGs
31 ("image/jpeg: inline") with their original aspect ratio
32 + You need PHP 4.3.0 or newer to use the "text/plain: external"
33 MIME-based transformation
34 + When using the "cookie" authentication method, the mcrypt extension is
35 strongly suggested for most users and is required for 64?bit machines.
36 Not using mcrypt will cause phpMyAdmin to load pages significantly
38 * MySQL 3.23.32 or newer (details);
39 * Web browser with cookies enabled.
43 phpMyAdmin can manage a whole MySQL server (needs a super-user) as well as a
44 single database. To accomplish the latter you'll need a properly set up MySQL
45 user who can read/write only the desired database. It's up to you to look up
46 the appropriate part in the MySQL manual.
48 Currently phpMyAdmin can:
50 * browse and drop databases, tables, views, fields and indexes
51 * create, copy, drop, rename and alter databases, tables, fields and indexes
52 * maintenance server, databases and tables, with proposals on server
54 * execute, edit and bookmark any SQL-statement, even batch-queries
55 * load text files into tables
56 * create^1 and read dumps of tables
57 * export^1 data to various formats: CSV, XML, PDF, ISO/IEC 26300 -
58 OpenDocument Text and Spreadsheet, Word, Excel and L^AT[E]X formats
59 * administer multiple servers
60 * manage MySQL users and privileges
61 * check referential integrity in MyISAM tables
62 * using Query-by-example (QBE), create complex queries automatically
63 connecting required tables
64 * create PDF graphics of your Database layout
65 * search globally in a database or a subset of it
66 * transform stored data into any format using a set of predefined functions,
67 like displaying BLOB-data as image or download-link
68 * support InnoDB tables and foreign keys (see FAQ 3.6)
69 * support mysqli, the improved MySQL extension (see FAQ 1.17)
70 * communicate in 54 different languages
74 Many people have difficulty understanding the concept of user management with
75 regards to phpMyAdmin. When a user logs in to phpMyAdmin, that username and
76 password are passed directly to MySQL. phpMyAdmin does no account management on
77 its own (other than allowing one to manipulate the MySQL user account
78 information); all users must be valid MySQL users.
80 ^1) phpMyAdmin can compress (Zip, GZip -RFC 1952- or Bzip2 formats) dumps and
81 CSV exports if you use PHP with Zlib support (--with-zlib) and/or Bzip2 support
82 (--with-bz2). Proper support may also need changes in php.ini.
88 3. Linked-tables infrastructure
89 4. Upgrading from an older version
90 5. Using authentication modes
92 phpMyAdmin does not apply any special security methods to the MySQL database
93 server. It is still the system administrator's job to grant permissions on the
94 MySQL databases properly. phpMyAdmin's "Privileges" page can be used for this.
96 Warning for Mac users:
97 if you are on a Mac OS version before OS X, StuffIt unstuffs with Mac formats.
98 So you'll have to resave as in BBEdit to Unix style ALL phpMyAdmin scripts
99 before uploading them to your server, as PHP seems not to like Mac-style end of
100 lines character ("\r").
104 1. Choose an appropriate distribution kit from the phpmyadmin.net Downloads
105 page. Some kits contain only the English messages, others contain all
106 languages in UTF-8 format (this should be fine in most situations), others
107 contain all languages and all character sets. We'll assume you chose a kit
108 whose name looks like phpMyAdmin-x.x.x-all-languages.tar.gz.
109 2. Untar or unzip the distribution (be sure to unzip the subdirectories): tar
110 -xzvf phpMyAdmin_x.x.x-all-languages.tar.gz in your webserver's document
111 root. If you don't have direct access to your document root, put the files
112 in a directory on your local machine, and, after step 4, transfer the
113 directory on your web server using, for example, ftp.
114 3. Ensure that all the scripts have the appropriate owner (if PHP is running
115 in safe mode, having some scripts with an owner different from the owner of
116 other scripts will be a problem). See FAQ 4.2 and FAQ 1.26 for suggestions.
117 4. Now you must configure your installation. There are two methods that can be
118 used. Traditionally, users have hand-edited a copy of config.inc.php, but
119 now a wizard-style setup script is provided for those who prefer a
120 graphical installation. Creating a config.inc.php file is still a quick way
121 to get started and needed for some advanced features.
122 + To manually create the file, simply use your text editor to create the
123 file config.inc.php (you can copy config.sample.inc.php to get minimal
124 configuration file) in the main (top-level) phpMyAdmin directory (the
125 one that contains index.php). phpMyAdmin first loads libraries/
126 config.default.php and then overrides those values with anything found
127 in config.inc.php. If the default value is okay for a particular
128 setting, there is no need to include it in config.inc.php. You'll need
129 a few directives to get going, a simple configuration may look like
133 $cfg['blowfish_secret'] = 'ba17c1ec07d65003'; // use here a value of your choice
137 $cfg['Servers'][$i]['auth_type'] = 'cookie';
140 Or, if you prefer to not be prompted every time you log in:
146 $cfg['Servers'][$i]['user'] = 'root';
147 $cfg['Servers'][$i]['password'] = 'cbb74bc'; // use here your password
150 For a full explanation of possible configuration values, see the
151 Configuration Section of this document.
152 + Instead of manually editing config.inc.php, you can use the Setup
153 Script. First you must manually create a folder config in the
154 phpMyAdmin directory. This is a security measure. On a Linux/Unix
155 system you can use the following commands:
158 mkdir config # create directory for saving
159 chmod o+rw config # give it world writable permissions
161 And to edit an existing configuration, copy it over first:
163 cp config.inc.php config/ # copy current configuration for editing
164 chmod o+w config/config.inc.php # give it world writable permissions
166 On other platforms, simply create the folder and ensure that your web
167 server has read and write access to it. FAQ 1.26 can help with this.
169 Next, open scripts/setup.php in your browser. Note that changes are not
170 saved to disk until explicitly choose Save from the Configuration area
171 of the screen. Normally the script saves the new config.inc.php to the
172 config/ directory, but if the webserver does not have the proper
173 permissions you may see the error "Cannot load or save configuration."
174 Ensure that the config/ directory exists and has the proper permissions
175 - or use the Download link to save the config file locally and upload
176 (via FTP or some similar means) to the proper location.
178 Once the file has been saved, it must be moved out of the config/
179 directory and the permissions must be reset, again as a security
182 mv config/config.inc.php . # move file to current directory
183 chmod o-rw config.inc.php # remove world read and write permissions
185 Now the file is ready to be used. You can choose to review or edit the
186 file with your favorite editor, if you prefer to set some advanced
187 options which the setup script does not provide.
188 5. If you are using the auth_type "config", it is suggested that you protect
189 the phpMyAdmin installation directory because using config does not require
190 a user to enter a password to access the phpMyAdmin installation. Use of an
191 alternate authentication method is recommended, for example with HTTP?AUTH
192 in a .htaccess file or switch to using auth_type cookie or http. See the
193 multi?user sub?section of this FAQ for additional information, especially
195 6. Open the main phpMyAdmin directory in your browser. phpMyAdmin should now
196 display a welcome screen and your databases, or a login dialog if using
197 HTTP or cookie authentication mode.
198 7. You should deny access to the ./libraries subfolder in your webserver
199 configuration. For Apache you can use supplied .htaccess file in that
200 folder, for other webservers, you should configure this yourself. Such
201 configuration prevents from possible path exposure and cross side scripting
202 vulnerabilities that might happen to be found in that code.
204 Linked-tables infrastructure
206 For a whole set of new features (bookmarks, comments, SQL-history,
207 PDF-generation, field contents transformation, etc.) you need to create a set
208 of special tables. Those tables can be located in your own database, or in a
209 central database for a multi-user installation (this database would then be
210 accessed by the controluser, so no other user should have rights to it).
212 Please look at your ./scripts/ directory, where you should find a file called
213 create_tables.sql. (If you are using a Windows server, pay special attention to
216 If your MySQL server's version is 4.1.2 or later, please use ./scripts/
217 create_tables_mysql_4_1_2+.sql instead, for a new installation.
219 If you already had this infrastructure and upgraded to MySQL 4.1.2 or later,
220 please use ./scripts/upgrade_tables_mysql_4_1_2+.sql.
222 You can use your phpMyAdmin to create the tables for you. Please be aware that
223 you may need special (administrator) privileges to create the database and
224 tables, and that the script may need some tuning, depending on the database
227 After having imported the ./scripts/create_tables.sql file, you should specify
228 the table names in your ./config.inc.php file. The directives used for that can
229 be found in the Configuration section. You will also need to have a controluser
230 with the proper rights to those tables (see section Using authentication modes
233 Upgrading from an older version
235 Simply copy ./config.inc.php from your previous installation into the newly
236 unpacked one. Configuration files from very old versions (2.3.0 or before) may
237 require some tweaking as some options have been changed or removed. For
238 compatibility with PHP 6, remove a set_magic_quotes_runtime(0); statement that
239 you might find near the end of your configuration file.
241 You should not copy libraries/config.default.php over config.inc.php because
242 the default configuration file is version-specific.
244 If you have upgraded your MySQL server from a version previous to 4.1.2 to
245 version 4.1.2 or newer and if you use the pmadb/linked table infrastructure,
246 you should run the SQL script found in scripts/upgrade_tables_mysql_4_1_2+.sql.
248 Using authentication modes
250 * HTTP and cookie authentication modes are recommended in a multi-user
251 environment where you want to give users access to their own database and
252 don't want them to play around with others.
253 Nevertheless be aware that MS Internet Explorer seems to be really buggy
254 about cookies, at least till version 6, and PHP 4.1.1 is also a bit buggy
256 Even in a single-user environment, you might prefer to use HTTP or cookie
257 mode so that your user/password pair are not in clear in the configuration
259 * HTTP and cookie authentication modes are more secure: the MySQL login
260 information does not need to be set in the phpMyAdmin configuration file
261 (except possibly for the controluser).
262 However, keep in mind that the password travels in plain text, unless you
263 are using the HTTPS protocol.
264 In cookie mode, the password is stored, encrypted with the blowfish
265 algorithm, in a temporary cookie.
266 * Note: starting with phpMyAdmin 2.6.1, this section is only applicable if
267 your MySQL server is previous to 4.1.2, or is running with
268 --skip-show-database.
270 For 'HTTP' and 'cookie' modes, phpMyAdmin needs a controluser that has only
271 the SELECT privilege on the `mysql`.`user` (all columns except `Password`),
272 `mysql`.`db` (all columns), `mysql`.`host` (all columns) and `mysql`.
273 `tables_priv` (all columns except `Grantor` and `Timestamp`) tables.
274 You must specify the details for the controluser in the config.inc.php file
275 under the $cfg['Servers'][$i]['controluser'] and $cfg['Servers'][$i]
276 ['controlpass'] settings.
277 The following example assumes you want to use pma as the controluser and
278 pmapass as the controlpass, but this is only an example: use something else
279 in your file! Input these statements from the phpMyAdmin SQL Query window
280 or mysql command?line client.
281 Of course you have to replace localhost with the webserver's host if it's
282 not the same as the MySQL server's one.
284 GRANT USAGE ON mysql.* TO 'pma'@'localhost' IDENTIFIED BY 'pmapass';
286 Host, User, Select_priv, Insert_priv, Update_priv, Delete_priv,
287 Create_priv, Drop_priv, Reload_priv, Shutdown_priv, Process_priv,
288 File_priv, Grant_priv, References_priv, Index_priv, Alter_priv,
289 Show_db_priv, Super_priv, Create_tmp_table_priv, Lock_tables_priv,
290 Execute_priv, Repl_slave_priv, Repl_client_priv
291 ) ON mysql.user TO 'pma'@'localhost';
292 GRANT SELECT ON mysql.db TO 'pma'@'localhost';
293 GRANT SELECT ON mysql.host TO 'pma'@'localhost';
294 GRANT SELECT (Host, Db, User, Table_name, Table_priv, Column_priv)
295 ON mysql.tables_priv TO 'pma'@'localhost';
297 If you are using an old MySQL version (below 4.0.2), please replace the
298 first GRANT SELECT query by this one:
301 Host, User, Select_priv, Insert_priv, Update_priv, Delete_priv,
302 Create_priv, Drop_priv, Reload_priv, Shutdown_priv, Process_priv,
303 File_priv, Grant_priv, References_priv, Index_priv, Alter_priv
304 ) ON mysql.user TO 'pma'@'localhost';
306 ... and if you want to use the many new relation and bookmark features:
308 GRANT SELECT, INSERT, UPDATE, DELETE ON <pma_db>.* TO 'pma'@'localhost';
310 (this of course requires that your linked-tables infrastructure be set up).
311 Of course, the above queries only work if your MySQL version supports the
312 GRANT command. This is the case since 3.22.11.
313 * Then each of the true users should be granted a set of privileges on a set
314 of particular databases. Normally you shouldn't give global privileges to
315 an ordinary user, unless you understand the impact of those privileges (for
316 example, you are creating a superuser).
317 For example, to grant the user real_user with all privileges on the
320 GRANT ALL PRIVILEGES ON user_base.* TO 'real_user'@localhost IDENTIFIED BY 'real_password';
322 What the user may now do is controlled entirely by the MySQL user
324 With HTTP or cookie authentication mode, you don't need to fill the user/
325 password fields inside the $cfg['Servers'] array.
327 'HTTP' authentication mode
329 * Uses HTTP Basic authentication method and allows you to log in as any valid
331 * Is supported with most PHP configurations. For IIS (ISAPI) support using
332 CGI PHP see FAQ 1.32, for using with Apache CGI see FAQ 1.35.
333 * See also FAQ 4.4 about not using the .htaccess mechanism along with 'HTTP'
336 'cookie' authentication mode
338 * You can use this method as a replacement for the HTTP authentication (for
339 example, if you're running IIS).
340 * Obviously, the user must enable cookies in the browser, but this is now a
341 requirement for all authentication modes.
342 * With this mode, the user can truly log out of phpMyAdmin and log in back
343 with the same username.
344 * If you want to log in to arbitrary server see $cfg['AllowArbitraryServer']
346 * As mentioned in the requirements section, having the mcrypt extension will
347 speed up access considerably, but is not required.
349 'signon' authentication mode
351 * This mode is a convenient way of using credentials from another application
352 to authenticate to phpMyAdmin.
353 * The other application has to store login information into session data.
354 * More details in the auth_type section.
356 'config' authentication mode
358 * This mode is the less secure one because it requires you to fill the $cfg
359 ['Servers'][$i]['user'] and $cfg['Servers'][$i]['password'] fields (and as
360 a result, anyone who can read your config.inc.php can discover your
361 username and password).
362 But you don't need to setup a "controluser" here: using the $cfg['Servers']
363 [$i]['only_db'] might be enough.
364 * In the ISP FAQ section, there is an entry explaining how to protect your
366 * For additional security in this mode, you may wish to consider the Host
367 authentication $cfg['Servers'][$i]['AllowDeny']['order'] and $cfg
368 ['Servers'][$i]['AllowDeny']['rules'] configuration directives.
369 * Unlike cookie and http, does not require a user to log in when first
370 loading the phpMyAdmin site. This is by design but could allow any user to
371 access your installation. Use of some restriction method is suggested,
372 perhaps a .htaccess file with the HTTP-AUTH directive or disallowing
373 incoming HTTP requests at one?s router or firewall will suffice (both of
374 which are beyond the scope of this manual but easily searchable with
379 Warning for Mac users: PHP does not seem to like Mac end of lines character ("\
380 r"). So ensure you choose the option that allows to use the *nix end of line
381 character ("\n") in your text editor before saving a script you have modified.
383 Configuration note: Almost all configurable data is placed in config.inc.php.
384 If this file does not exist, please refer to the Quick install section to
385 create one. This file only needs to contain the parameters you want to change
386 from their corresponding default value in libraries/config.default.php.
388 The parameters which relate to design (like colors) are placed in themes/
389 themename/layout.inc.php. You might also want to create config.footer.inc.php
390 and config.header.inc.php files to add your site specific code to be included
391 on start and end of each page.
393 $cfg['PmaAbsoluteUri'] string
394 Sets here the complete URL (with full path) to your phpMyAdmin
395 installation's directory. E.g. http://www.your_web.net/
396 path_to_your_phpMyAdmin_directory/. Note also that the URL on some web
397 servers are case?sensitive. Don?t forget the trailing slash at the end.
399 Starting with version 2.3.0, it is advisable to try leaving this blank. In
400 most cases phpMyAdmin automatically detects the proper setting. Users of
401 port forwarding will need to set PmaAbsoluteUri (more info). A good test is
402 to browse a table, edit a row and save it. There should be an error message
403 if phpMyAdmin is having trouble auto?detecting the correct value. If you
404 get an error that this must be set or if the autodetect code fails to
405 detect your path, please post a bug report on our bug tracker so we can
407 $cfg['PmaNoRelation_DisableWarning'] boolean
408 Starting with version 2.3.0 phpMyAdmin offers a lot of features to work
409 with master / foreign ? tables (see $cfg['Servers'][$i]['pmadb']).
410 If you tried to set this up and it does not work for you, have a look on
411 the "Structure" page of one database where you would like to use it. You
412 will find a link that will analyze why those features have been disabled.
413 If you do not want to use those features set this variable to TRUE to stop
414 this message from appearing.
415 $cfg['SuhosinDisableWarning'] boolean
416 A warning is displayed on the main page if Suhosin is detected. You can set
417 this parameter to TRUE to stop this message from appearing.
418 $cfg['AllowThirdPartyFraming'] boolean
419 Setting this to true allows a page located on a different domain to call
420 phpMyAdmin inside a frame, and is a potential security hole allowing
421 cross-frame scripting attacks.
422 $cfg['blowfish_secret'] string
423 The "cookie" auth_type uses blowfish algorithm to encrypt the password.
424 If you are using the "cookie" auth_type, enter here a random passphrase of
425 your choice. It will be used internally by the blowfish algorithm: you
426 won?t be prompted for this passphrase. The maximum number of characters for
427 this parameter seems to be 46.
428 $cfg['Servers'] array
429 Since version 1.4.2, phpMyAdmin supports the administration of multiple
430 MySQL servers. Therefore, a $cfg['Servers']-array has been added which
431 contains the login information for the different servers. The first $cfg
432 ['Servers'][$i]['host'] contains the hostname of the first server, the
433 second $cfg['Servers'][$i]['host'] the hostname of the second server, etc.
434 In ./libraries/config.default.php, there is only one section for server
435 definition, however you can put as many as you need in ./config.inc.php,
436 copy that block or needed parts (you don't have to define all settings,
437 just those you need to change).
438 $cfg['Servers'][$i]['host'] string
439 The hostname or IP address of your $i-th MySQL-server. E.g. localhost.
440 $cfg['Servers'][$i]['port'] string
441 The port-number of your $i-th MySQL-server. Default is 3306 (leave blank).
442 If you use "localhost" as the hostname, MySQL ignores this port number and
443 connects with the socket, so if you want to connect to a port different
444 from the default port, use "127.0.0.1" or the real hostname in $cfg
445 ['Servers'][$i]['host'].
446 $cfg['Servers'][$i]['socket'] string
447 The path to the socket to use. Leave blank for default.
448 To determine the correct socket, check your MySQL configuration or, using
449 the mysql command?line client, issue the status command. Among the
450 resulting information displayed will be the socket used.
451 $cfg['Servers'][$i]['ssl'] boolean
452 Whether to enable SSL for connection to MySQL server.
453 $cfg['Servers'][$i]['connect_type'] string
454 What type connection to use with the MySQL server. Your options are
455 'socket' and 'tcp'. It defaults to 'tcp' as that is nearly guaranteed to be
456 available on all MySQL servers, while sockets are not supported on some
459 To use the socket mode, your MySQL server must be on the same machine as
461 $cfg['Servers'][$i]['extension'] string
462 What php MySQL extension to use for the connection. Valid options are:
464 mysql : The classic MySQL extension. This is the recommended and default
467 mysqli : The improved MySQL extension. This extension became available with
468 php 5.0.0 and is the recommended way to connect to a server running MySQL
470 $cfg['Servers'][$i]['compress'] boolean
471 Whether to use a compressed protocol for the MySQL server connection or not
473 This feature requires PHP >= 4.3.0.
474 $cfg['Servers'][$i]['controluser'] string
475 $cfg['Servers'][$i]['controlpass'] string
476 This special account is used for 2 distinct purposes: to make possible all
477 relational features (see $cfg['Servers'][$i]['pmadb']) and, for a MySQL
478 server previous to 4.1.2 or running with --skip-show-database, to enable a
479 multi-user installation (HTTP or cookie authentication mode).
481 When using HTTP or cookie authentication modes (or 'config' authentication
482 mode since phpMyAdmin 2.2.1), you need to supply the details of a MySQL
483 account that has SELECT privilege on the mysql.user (all columns except
484 "Password"), mysql.db (all columns) and mysql.tables_priv (all columns
485 except "Grantor" and "Timestamp") tables. This account is used to check
486 what databases the user will see at login.
487 Please see the install section on "Using authentication modes" for more
490 In phpMyAdmin versions before 2.2.5, those were called "stduser/stdpass".
491 $cfg['Servers'][$i]['auth_type'] string ['HTTP'|'http'|'cookie'|'config'|
493 Whether config or cookie or HTTP or signon authentication should be used
495 + 'config' authentication ($auth_type = 'config') is the plain old way:
496 username and password are stored in config.inc.php.
497 + 'cookie' authentication mode ($auth_type = 'cookie') as introduced in
498 2.2.3 allows you to log in as any valid MySQL user with the help of
499 cookies. Username and password are stored in cookies during the session
500 and password is deleted when it ends. This can also allow you to log in
501 in arbitrary server if $cfg['AllowArbitraryServer'] enabled.
502 + 'HTTP' authentication (was called 'advanced' in previous versions and
503 can be written also as 'http') ($auth_type = 'HTTP') as introduced in
504 1.3.0 allows you to log in as any valid MySQL user via HTTP-Auth.
505 + 'signon' authentication mode ($auth_type = 'signon') as introduced in
506 2.10.0 allows you to log in from prepared PHP session data. This is
507 useful for implementing single signon from another application. Sample
508 way how to seed session is in signon example: scripts/signon.php. You
509 need to configure session name and signon URL to use this
510 authentication method.
511 Please see the install section on "Using authentication modes" for more
513 $cfg['Servers'][$i]['user'] string
514 $cfg['Servers'][$i]['password'] string
515 When using auth_type = 'config', this is the user/password-pair which
516 phpMyAdmin will use to connect to the MySQL server. This user/password pair
517 is not needed when HTTP or cookie authentication is used and should be
519 $cfg['Servers'][$i]['nopassword'] boolean
520 Allow attempt to log in without password when a login with password fails.
521 This can be used together with http authentication, when authentication is
522 done some other way and phpMyAdmin gets user name from auth and uses empty
523 password for connecting to MySQL. Password login is still tried first, but
524 as fallback, no password method is tried.
525 $cfg['Servers'][$i]['only_db'] string or array
526 If set to a (an array of) database name(s), only this (these) database(s)
527 will be shown to the user. Since phpMyAdmin 2.2.1, this/these database(s)
528 name(s) may contain MySQL wildcards characters ("_" and "%"): if you want
529 to use literal instances of these characters, escape them (I.E. use 'my\
530 _db' and not 'my_db').
531 This setting is an efficient way to lower the server load since the latter
532 does not need to send MySQL requests to build the available database list.
533 But it does not replace the privileges rules of the MySQL database server.
534 If set, it just means only these databases will be displayed but not that
535 all other databases can't be used.
537 An example of using more that one database: $cfg['Servers'][$i]['only_db']
538 = array('db1', 'db2');
540 As of phpMyAdmin 2.5.5 the order inside the array is used for sorting the
541 databases in the left frame, so that you can individually arrange your
543 If you want to have certain databases at the top, but don't care about the
544 others, you do not need to specify all other databases. Use: $cfg
545 ['Servers'][$i]['only_db'] = array('db3', 'db4', '*'); instead to tell
546 phpMyAdmin that it should display db3 and db4 on top, and the rest in
548 $cfg['Servers'][$i]['hide_db'] string
549 Regular expression for hiding some databases. This only hides them from
550 listing, but a user is still able to access them (using, for example, the
551 SQL query area). To limit access, use the MySQL privilege system.
553 For example, to hide all databases starting with the letter "a", use
555 $cfg['Servers'][$i]['hide_db'] = '^a';
557 and to hide both "db1" and "db2" use
559 $cfg['Servers'][$i]['hide_db'] = '(db1|db2)';
561 More information on regular expressions can be found in the PCRE pattern
562 syntax portion of the PHP reference manual.
563 $cfg['Servers'][$i]['verbose'] string
564 Only useful when using phpMyAdmin with multiple server entries. If set,
565 this string will be displayed instead of the hostname in the pull-down menu
566 on the main page. This can be useful if you want to show only certain
567 databases on your system, for example. For HTTP auth, all non-US-ASCII
568 characters will be stripped.
569 $cfg['Servers'][$i]['pmadb'] string
570 The name of the database containing the linked-tables infrastructure.
572 See the Linked-tables infrastructure section in this document to see the
573 benefits of this infrastructure, and for a quick way of creating this
574 database and the needed tables.
576 If you are the only user of this phpMyAdmin installation, you can use your
577 current database to store those special tables; in this case, just put your
578 current database name in $cfg['Servers'][$i]['pmadb']. For a multi-user
579 installation, set this parameter to the name of your central database
580 containing the linked-tables infrastructure.
581 $cfg['Servers'][$i]['bookmarktable'] string
582 Since release 2.2.0 phpMyAdmin allows users to bookmark queries. This can
583 be useful for queries you often run.
585 To allow the usage of this functionality:
586 + set up pmadb and the linked-tables infrastructure
587 + enter the table name in $cfg['Servers'][$i]['bookmarktable']
588 $cfg['Servers'][$i]['relation'] string
589 Since release 2.2.4 you can describe, in a special 'relation' table, which
590 field is a key in another table (a foreign key). phpMyAdmin currently uses
592 + make clickable, when you browse the master table, the data values that
593 point to the foreign table;
594 + display in an optional tool-tip the "display field" when browsing the
595 master table, if you move the mouse to a column containing a foreign
596 key (use also the 'table_info' table);
598 + in edit/insert mode, display a drop-down list of possible foreign keys
599 (key value and "display field" are shown)
601 + display links on the table properties page, to check referential
602 integrity (display missing foreign keys) for each described key;
603 + in query-by-example, create automatic joins (see FAQ 6.6)
604 + enable you to get a PDF schema of your database (also uses the
606 The keys can be numeric or character.
608 To allow the usage of this functionality:
609 + set up pmadb and the linked-tables infrastructure
610 + put the relation table name in $cfg['Servers'][$i]['relation']
611 + now as normal user open phpMyAdmin and for each one of your tables
612 where you want to use this feature, click "Structure/Relation view/"
613 and choose foreign fields.
614 Please note that in the current version, master_db must be the same as
615 foreign_db. Those fields have been put in future development of the
617 $cfg['Servers'][$i]['table_info'] string
618 Since release 2.3.0 you can describe, in a special 'table_info' table,
619 which field is to be displayed as a tool-tip when moving the cursor over
620 the corresponding key.
621 This configuration variable will hold the name of this special table. To
622 allow the usage of this functionality:
623 + set up pmadb and the linked-tables infrastructure
624 + put the table name in $cfg['Servers'][$i]['table_info']
625 + then for each table where you want to use this feature, click
626 "Structure/Relation view/Choose field to display" to choose the field.
627 Usage tip: Display field.
628 $cfg['Servers'][$i]['table_coords'] string
629 $cfg['Servers'][$i]['pdf_pages'] string
630 Since release 2.3.0 you can have phpMyAdmin create PDF pages showing the
631 relations between your tables. To do this it needs two tables "pdf_pages"
632 (storing information about the available PDF pages) and "table_coords"
633 (storing coordinates where each table will be placed on a PDF schema
636 You must be using the "relation" feature.
638 To allow the usage of this functionality:
639 + set up pmadb and the linked-tables infrastructure
640 + put the correct table names in $cfg['Servers'][$i]['table_coords'] and
641 $cfg['Servers'][$i]['pdf_pages']
642 Usage tips: PDF output.
643 $cfg['Servers'][$i]['column_info'] string
644 Since release 2.3.0 you can store comments to describe each column for each
645 table. These will then be shown on the "printview".
647 Starting with release 2.5.0, comments are consequently used on the table
648 property pages and table browse view, showing up as tool-tips above the
649 column name (properties page) or embedded within the header of table in
650 browse view. They can also be shown in a table dump. Please see the
651 relevant configuration directives later on.
653 Also new in release 2.5.0 is a MIME-transformation system which is also
654 based on the following table structure. See Transformations for further
655 information. To use the MIME-transformation system, your column_info table
656 has to have the three new fields 'mimetype', 'transformation',
657 'transformation_options'.
659 To allow the usage of this functionality:
660 + set up pmadb and the linked-tables infrastructure
661 + put the table name in $cfg['Servers'][$i]['column_info']
662 + to update your PRE-2.5.0 Column_comments Table use this:
664 ALTER TABLE `pma_column_comments`
665 ADD `mimetype` VARCHAR( 255 ) NOT NULL,
666 ADD `transformation` VARCHAR( 255 ) NOT NULL,
667 ADD `transformation_options` VARCHAR( 255 ) NOT NULL;
669 and remember that the Variable in config.inc.php has been renamed from
670 $cfg['Servers'][$i]['column_comments'] to $cfg['Servers'][$i]
672 $cfg['Servers'][$i]['history'] string
673 Since release 2.5.0 you can store your SQL history, which means all queries
674 you entered manually into the phpMyAdmin interface. If you don't want to
675 use a table-based history, you can use the JavaScript-based history. Using
676 that, all your history items are deleted when closing the window.
678 Using $cfg['QueryHistoryMax'] you can specify an amount of history items
679 you want to have on hold. On every login, this list gets cut to the maximum
682 The query history is only available if JavaScript is enabled in your
685 To allow the usage of this functionality:
686 + set up pmadb and the linked-tables infrastructure
687 + put the table name in $cfg['Servers'][$i]['history']
688 $cfg['Servers'][$i]['designer_coords'] string
689 Since release 2.10.0 a Designer interface is available; it permits to
690 visually manage the relations.
692 To allow the usage of this functionality:
693 + set up pmadb and the linked-tables infrastructure
694 + put the table name in $cfg['Servers'][$i]['designer_coords']
695 $cfg['Servers'][$i]['verbose_check'] boolean
696 Because release 2.5.0 introduced the new MIME-transformation support, the
697 column_info table got enhanced with three new fields. If the above variable
698 is set to TRUE (default) phpMyAdmin will check if you have the latest table
699 structure available. If not, it will emit a warning to the superuser.
701 You can disable this checking behavior by setting the variable to false,
702 which should offer a performance increase.
704 Recommended to set to FALSE, when you are sure, your table structure is up
706 $cfg['Servers'][$i]['AllowRoot'] boolean
707 Whether to allow root access. This is just simplification of rules below.
708 $cfg['Servers'][$i]['AllowDeny']['order'] string
709 If your rule order is empty, then IP authentication is disabled.
711 If your rule order is set to 'deny,allow' then the system applies all deny
712 rules followed by allow rules. Access is allowed by default. Any client
713 which does not match a Deny command or does match an Allow command will be
714 allowed access to the server.
716 If your rule order is set to 'allow,deny' then the system applies all allow
717 rules followed by deny rules. Access is denied by default. Any client which
718 does not match an Allow directive or does match a Deny directive will be
719 denied access to the server.
721 If your rule order is set to 'explicit', the authentication is performed in
722 a similar fashion to rule order 'deny,allow', with the added restriction
723 that your host/username combination must be listed in the allow rules, and
724 not listed in the deny rules. This is the most secure means of using Allow/
725 Deny rules, and was available in Apache by specifying allow and deny rules
726 without setting any order.
728 Please also see $cfg['TrustedProxies'] for detecting IP address behind
730 $cfg['Servers'][$i]['AllowDeny']['rules'] array of strings
731 The general format for the rules is as such:
733 <'allow' | 'deny'> <username> [from] <ipmask>
735 If you wish to match all users, it is possible to use a '%' as a wildcard
736 in the username field.
737 There are a few shortcuts you can use in the ipmask field as well (please
738 note that those containing SERVER_ADDRESS might not be available on all
742 'localhost' -> 127.0.0.1/8
743 'localnetA' -> SERVER_ADDRESS/8
744 'localnetB' -> SERVER_ADDRESS/16
745 'localnetC' -> SERVER_ADDRESS/24
747 Having an empty rule list is equivalent to either using 'allow % from all'
748 if your rule order is set to 'deny,allow' or 'deny % from all' if your rule
749 order is set to 'allow,deny' or 'explicit'.
751 For the IP matching system, the following work:
752 xxx.xxx.xxx.xxx (an exact IP address)
753 xxx.xxx.xxx.[yyy-zzz] (an IP address range)
754 xxx.xxx.xxx.xxx/nn (CIDR, Classless Inter-Domain Routing type IP addresses)
755 But the following does not work:
756 xxx.xxx.xxx.xx[yyy-zzz] (partial IP address range)
757 $cfg['Servers'][$i]['SignonSession'] string
758 Name of session which will be used for signon authentication method.
759 $cfg['Servers'][$i]['SignonURL'] string
760 URL where user will be redirected to log in for signon authentication
761 method. Should be absolute including protocol.
762 $cfg['Servers'][$i]['LogoutURL'] string
763 URL where user will be redirected after logout (doesn't affect config
764 authentication method). Should be absolute including protocol.
765 $cfg['ServerDefault'] integer
766 If you have more than one server configured, you can set $cfg
767 ['ServerDefault'] to any one of them to autoconnect to that server when
768 phpMyAdmin is started, or set it to 0 to be given a list of servers without
770 If you have only one server configured, $cfg['ServerDefault'] MUST be set
772 $cfg['MaxDbList'] integer
773 The maximum number of database names to be displayed in the navigation
774 frame and the database list.
775 $cfg['MaxTableList'] integer
776 The maximum number of table names to be displayed in the main panel's list
777 (except on the Export page). This limit is also enforced in the navigation
778 panel when in Light mode.
779 $cfg['MaxCharactersInDisplayedSQL'] integer
780 The maximum number of characters when a SQL query is displayed. The default
781 limit of 1000 should be correct to avoid the display of tons of hexadecimal
782 codes that represent BLOBs, but some users have real SQL queries that are
783 longer than 1000 characters. Also, if a query's length exceeds this limit,
784 this query is not saved in the history.
785 $cfg['OBGzip'] string/boolean
786 Defines whether to use GZip output buffering for increased speed in HTTP
788 Set to true/false for enabling/disabling. When set to 'auto' (string),
789 phpMyAdmin tries to enable output buffering and will automatically disable
790 it if your browser has some problems with buffering. IE6 with a certain
791 patch is known to cause data corruption when having enabled buffering.
792 $cfg['PersistentConnections'] boolean
793 Whether persistent connections should be used or not (mysql_connect or
795 $cfg['ForceSSL'] boolean
796 Whether to force using https while accessing phpMyAdmin.
797 $cfg['ExecTimeLimit'] integer [number of seconds]
798 Set the number of seconds a script is allowed to run. If seconds is set to
799 zero, no time limit is imposed.
800 This setting is used while importing/exporting dump files but has no effect
801 when PHP is running in safe mode.
802 $cfg['MemoryLimit'] integer [number of bytes]
803 Set the number of bytes a script is allowed to allocate. If number set to
804 zero, no limit is imposed.
805 This setting is used while importing/exporting dump files but has no effect
806 when PHP is running in safe mode.
807 You can also use any string as in php.ini, eg. '16M'.
808 $cfg['SkipLockedTables'] boolean
809 Mark used tables and make it possible to show databases with locked tables
810 (since MySQL 3.23.30).
811 $cfg['ShowSQL'] boolean
812 Defines whether SQL queries generated by phpMyAdmin should be displayed or
814 $cfg['AllowUserDropDatabase'] boolean
815 Defines whether normal users (non-administrator) are allowed to delete
816 their own database or not. If set as FALSE, the link "Drop Database" will
817 not be shown, and even a "DROP DATABASE mydatabase" will be rejected. Quite
818 practical for ISP's with many customers.
819 Please note that this limitation of SQL queries is not as strict as when
820 using MySQL privileges. This is due to nature of SQL queries which might be
821 quite complicated. So this choice should be viewed as help to avoid
822 accidental dropping rather than strict privilege limitation.
823 $cfg['Confirm'] boolean
824 Whether a warning ("Are your really sure...") should be displayed when
825 you're about to lose data.
826 $cfg['LoginCookieRecall'] boolean
827 Define whether the previous login should be recalled or not in cookie
829 $cfg['LoginCookieValidity'] integer [number of seconds]
830 Define how long is login cookie valid.
831 $cfg['LoginCookieStore'] integer [number of seconds]
832 Define how long is login cookie should be stored in browser. Default 0
833 means that it will be kept for existing session. This is recommended for
834 not trusted environments.
835 $cfg['LoginCookieDeleteAll'] boolean
836 If enabled (default), logout deletes cookies for all servers, otherwise
837 only for current one. Setting this to false makes it easy to forget to log
838 out from other server, when you are using more of them.
839 $cfg['UseDbSearch'] boolean
840 Define whether the "search string inside database" is enabled or not.
841 $cfg['IgnoreMultiSubmitErrors'] boolean
842 Define whether phpMyAdmin will continue executing a multi-query statement
843 if one of the queries fails. Default is to abort execution.
844 $cfg['VerboseMultiSubmit'] boolean
845 Define whether phpMyAdmin will output the results of each query of a
846 multi-query statement embedded into the SQL output as inline comments.
848 $cfg['AllowArbitraryServer'] boolean
849 If enabled allows you to log in to arbitrary servers using cookie auth.
851 NOTE: Please use this carefully, as this may allow users access to MySQL
852 servers behind the firewall where your HTTP server is placed.
853 $cfg['LeftFrameLight'] boolean
854 Defines whether to use a select-based menu and display only the current
855 tables in the left frame (smaller page). Only in Non-Lightmode you can use
856 the feature to display nested folders using $cfg['LeftFrameTableSeparator']
857 $cfg['LeftFrameDBTree'] boolean
858 In light mode, defines whether to display the names of databases (in the
859 selector) using a tree, see also $cfg['LeftFrameDBSeparator'].
860 $cfg['LeftFrameDBSeparator'] string
861 The string used to separate the parts of the database name when showing
863 $cfg['LeftFrameTableSeparator'] string
864 Defines a string to be used to nest table spaces. Defaults to '__'. This
865 means if you have tables like 'first__second__third' this will be shown as
866 a three-level hierarchy like: first > second > third. If set to FALSE or
867 empty, the feature is disabled. NOTE: You should not use this separator at
868 the beginning or end of a table name or multiple times after another
869 without any other characters in between.
870 $cfg['LeftFrameTableLevel'] string
871 Defines how many sublevels should be displayed when splitting up tables by
873 $cfg['ShowTooltip'] boolean
874 Defines whether to display table comment as tool-tip in left frame or not.
875 $cfg['ShowTooltipAliasDB'] boolean
876 If tool-tips are enabled and a DB comment is set, this will flip the
877 comment and the real name. That means that if you have a table called
878 'user0001' and add the comment 'MyName' on it, you will see the name
879 'MyName' used consequently in the left frame and the tool-tip shows the
881 $cfg['ShowTooltipAliasTB'] boolean/string
882 Same as $cfg['ShowTooltipAliasDB'], except this works for table names. When
883 setting this to 'nested', the Alias of the Tablename is only used to split/
884 nest the tables according to the $cfg['LeftFrameTableSeparator'] directive.
885 So only the folder is called like the Alias, the tablename itself stays the
887 $cfg['LeftDisplayLogo'] boolean
888 Defines whether or not to display the phpMyAdmin logo at the top of the
889 left frame. Defaults to TRUE.
890 $cfg['LeftLogoLink'] string
891 Enter URL where logo in the navigation frame will point to. For use
892 especially with self made theme which changes this. The default value for
894 $cfg['LeftLogoLinkWindow'] string
895 Whether to open the linked page in the main window (main) or in a new one
896 (new). Note: use new if you are linking to phpmyadmin.net.
897 $cfg['LeftDisplayServers'] boolean
898 Defines whether or not to display a server choice at the top of the left
899 frame. Defaults to FALSE.
900 $cfg['DisplayServersList'] boolean
901 Defines whether to display this server choice as links instead of in a
902 drop-down. Defaults to FALSE (drop-down).
903 $cfg['DisplayDatabasesList'] boolean or text
904 Defines whether to display database choice in light navigation frame as
905 links instead of in a drop-down. Defaults to 'auto' - on main page list is
906 shown, when database is selected, only drop down is displayed.
907 $cfg['ShowStats'] boolean
908 Defines whether or not to display space usage and statistics about
909 databases and tables.
910 Note that statistics requires at least MySQL 3.23.3 and that, at this date,
911 MySQL doesn't return such information for Berkeley DB tables.
912 $cfg['ShowServerInfo'] boolean
913 Defines whether to display detailed server information on main page. You
914 can additionally hide more information by using $cfg['Servers'][$i]
916 $cfg['ShowPhpInfo'] boolean
917 $cfg['ShowChgPassword'] boolean
918 $cfg['ShowCreateDb'] boolean
919 Defines whether to display the "PHP information" and "Change password "
920 links and form for creating database or not at the starting main (right)
921 frame. This setting does not check MySQL commands entered directly.
923 Please note that to block the usage of phpinfo() in scripts, you have to
924 put this in your php.ini:
926 disable_functions = phpinfo()
928 Also note that enabling the "Change password " link has no effect with
929 "config" authentication mode: because of the hard coded password value in
930 the configuration file, end users can't be allowed to change their
932 $cfg['SuggestDBName'] boolean
933 Defines whether to suggest a database name on the "Create Database" form or
934 to keep the textfield empty.
935 $cfg['ShowBlob'] boolean
936 Defines whether or not BLOB fields are shown when browsing a table's
938 $cfg['NavigationBarIconic'] string
939 Defines whether navigation bar buttons and the right panel top menu contain
940 text or symbols only. A value of TRUE displays icons, FALSE displays text
941 and 'both' displays both icons and text.
942 $cfg['ShowAll'] boolean
943 Defines whether a user should be displayed a "show all (records)" button in
945 $cfg['MaxRows'] integer
946 Number of rows displayed when browsing a result set. If the result set
947 contains more rows, "Previous" and "Next" links will be shown.
948 $cfg['Order'] string [DESC|ASC|SMART]
949 Defines whether fields are displayed in ascending (ASC) order, in
950 descending (DESC) order or in a "smart" (SMART) order - I.E. descending
951 order for fields of type TIME, DATE, DATETIME and TIMESTAMP, ascending
952 order else- by default.
953 $cfg['ProtectBinary'] boolean or string
954 Defines whether BLOB or BINARY fields are protected from editing when
955 browsing a table's content. Valid values are:
956 + FALSE to allow editing of all fields;
957 + 'blob' to allow editing of all fields except BLOBS;
958 + 'all' to disallow editing of all BINARY or BLOB fields.
959 $cfg['ShowFunctionFields'] boolean
960 Defines whether or not MySQL functions fields should be initially displayed
961 in edit/insert mode. Since version 2.10, the user can toggle this setting
963 $cfg['CharEditing'] string
964 Defines which type of editing controls should be used for CHAR and VARCHAR
965 fields. Possible values are:
966 + input - this allows to limit size of text to size of field in MySQL,
967 but has problems with newlines in fields
968 + textarea - no problems with newlines in fields, but also no length
970 Default is old behavior so input.
971 $cfg['InsertRows'] integer
972 Defines the maximum number of concurrent entries for the Insert page.
973 $cfg['ForeignKeyMaxLimit'] integer
974 If there are fewer items than this in the set of foreign keys, then a
975 drop-down box of foreign keys is presented, in the style described by the
976 $cfg['ForeignKeyDropdownOrder'] setting.
977 $cfg['ForeignKeyDropdownOrder'] array
978 For the foreign key drop-down fields, there are several methods of display,
979 offering both the key and value data. The contents of the array should be
980 one or both of the following strings: 'content-id', 'id-content'.
981 $cfg['ZipDump'] boolean
982 $cfg['GZipDump'] boolean
983 $cfg['BZipDump'] boolean
984 Defines whether to allow the use of zip/GZip/BZip2 compression when
986 $cfg['CompressOnFly'] boolean
987 Defines whether to allow on the fly compression for GZip/BZip2 compressed
988 exports. This doesn't affect smaller dumps and allows users to create
989 larger dumps that won't otherwise fit in memory due to php memory limit.
990 Produced files contain more GZip/BZip2 headers, but all normal programs
991 handle this correctly.
992 $cfg['LightTabs'] boolean
993 If set to TRUE, use less graphically intense tabs on the top of the
995 $cfg['PropertiesIconic'] string
996 If set to TRUE, will display icons instead of text for db and table
997 properties links (like 'Browse', 'Select', 'Insert', ...).
998 Can be set to 'both' if you want icons AND text.
999 When set to FALSE, will only show text.
1000 $cfg['PropertiesNumColumns'] integer
1001 How many columns will be utilized to display the tables on the database
1002 property view? Default is 1 column. When setting this to a value larger
1003 than 1, the type of the database will be omitted for more display space.
1004 $cfg['DefaultTabServer'] string
1005 Defines the tab displayed by default on server view. Possible values:
1006 "main.php" (recommended for multi-user setups), "server_databases.php",
1007 "server_status.php", "server_variables.php", "server_privileges.php" or
1008 "server_processlist.php".
1009 $cfg['DefaultTabDatabase'] string
1010 Defines the tab displayed by default on database view. Possible values:
1011 "db_structure.php", "db_sql.php" or "db_search.php".
1012 $cfg['DefaultTabTable'] string
1013 Defines the tab displayed by default on table view. Possible values:
1014 "tbl_structure.php", "tbl_sql.php", "tbl_select.php", "tbl_change.php" or
1016 $cfg['MySQLManualBase'] string
1017 If set to an URL which points to the MySQL documentation (type depends on
1018 $cfg['MySQLManualType']), appropriate help links are generated.
1019 See MySQL Documentation page for more information about MySQL manuals and
1021 $cfg['MySQLManualType'] string
1022 Type of MySQL documentation:
1023 + viewable - "viewable online", current one used on MySQL website
1024 + searchable - "Searchable, with user comments"
1025 + chapters - "HTML, one page per chapter"
1026 + big - "HTML, all on one page"
1027 + none - do not show documentation links
1028 $cfg['DefaultLang'] string
1029 Defines the default language to use, if not browser-defined or
1031 See the select_lang.lib.php script to know the valid values for this
1033 $cfg['DefaultConnectionCollation'] string
1034 Defines the default connection collation to use, if not user-defined.
1035 See the MySQL documentation for list of possible values.
1037 Force: always use this language (must be defined in the select_lang.lib.php
1039 $cfg['FilterLanguages'] string
1040 Limit list of available languages to those matching the given regular
1041 expression. For example if you want only Czech and English, you should set
1042 filter to '^(cs|en)'.
1043 $cfg['DefaultCharset'] string
1044 Default character set to use for recoding of MySQL queries. This must be
1045 enabled and it's described by $cfg['AllowAnywhereRecoding'] option.
1046 You can give here any character set which is in $cfg['AvailableCharsets']
1047 array and this is just default choice, user can select any of them.
1048 $cfg['AllowAnywhereRecoding'] boolean
1049 Allow character set recoding of MySQL queries. You need recode or iconv
1050 support (compiled in or module) in PHP to allow MySQL queries recoding and
1051 used language file must have it enabled (by default only these which are in
1052 Unicode, just to avoid losing some characters).
1054 Setting this to TRUE also activates a pull-down menu in the Export page, to
1055 choose the character set when exporting a file.
1056 $cfg['RecodingEngine'] string
1057 You can select here which functions will be used for character set
1058 conversion. Possible values are:
1059 + auto - automatically use available one (first is tested iconv, then
1061 + iconv - use iconv or libiconv functions
1062 + recode - use recode_string function
1064 $cfg['IconvExtraParams'] string
1065 Specify some parameters for iconv used in charset conversion. See iconv
1066 documentation for details. By default //TRANSLIT is used, so that invalid
1067 characters will be transliterated.
1068 $cfg['AvailableCharsets'] array
1069 Available character sets for MySQL conversion. You can add your own (any of
1070 supported by recode/iconv) or remove these which you don't use. Character
1071 sets will be shown in same order as here listed, so if you frequently use
1072 some of these move them to the top.
1073 $cfg['TrustedProxies'] array
1074 Lists proxies and HTTP headers which are trusted for IP Allow/Deny. This
1075 list is by default empty, you need to fill in some trusted proxy servers if
1076 you want to use rules for IP addresses behind proxy.
1078 The following example specifies that phpMyAdmin should trust a
1079 HTTP_X_FORWARDED_FOR (X-Forwarded-For) header coming from the proxy
1082 $cfg['TrustedProxies'] =
1083 array('1.2.3.4' => 'HTTP_X_FORWARDED_FOR');
1085 The $cfg['Servers'][$i]['AllowDeny']['rules'] directive uses the client's
1086 IP address as usual.
1087 $cfg['GD2Available'] string
1088 Specifies whether GD >= 2 is available. If yes it can be used for MIME
1090 Possible values are:
1091 + auto - automatically detect, this is a bit expensive operation for php
1092 < 4.3.0 so it is preferred to change this according to your server real
1094 + yes - GD 2 functions can be used
1095 + no - GD 2 function cannot be used
1097 $cfg['NaviWidth'] integer
1098 Navi frame width in pixels. See themes/themename/layout.inc.php.
1099 $cfg['NaviBackground'] string [valid css code for background]
1100 $cfg['MainBackground'] string [valid css code for background]
1101 The background styles used for both the frames. See themes/themename/
1103 $cfg['NaviPointerBackground'] string [valid css code for background]
1104 $cfg['NaviPointerColor'] string [valid css color]
1105 The style used for the pointer in the navi frame. See themes/themename/
1107 $cfg['NaviDatabaseNameColor'] string [valid css code]
1108 The color used for the database name in the navi frame. See themes/
1109 themename/layout.inc.php.
1110 $cfg['LeftPointerEnable'] boolean
1111 A value of TRUE activates the navi pointer (when LeftFrameLight is FALSE).
1112 $cfg['Border'] integer
1113 The size of a table's border. See themes/themename/layout.inc.php.
1114 $cfg['ThBackground'] string [valid css code for background]
1115 $cfg['ThColor'] string [valid css color]
1116 The style used for table headers. See themes/themename/layout.inc.php.
1117 $cfg['BgOne'] string [HTML color]
1118 The color (HTML) #1 for table rows. See themes/themename/layout.inc.php.
1119 $cfg['BgTwo'] string [HTML color]
1120 The color (HTML) #2 for table rows. See themes/themename/layout.inc.php.
1121 $cfg['BrowsePointerBackground'] string [HTML color]
1122 $cfg['BrowsePointerColor'] string [HTML color]
1123 $cfg['BrowseMarkerBackground'] string [HTML color]
1124 $cfg['BrowseMarkerColor'] string [HTML color]
1125 The colors (HTML) uses for the pointer and the marker in browse mode.
1126 The former feature highlights the row over which your mouse is passing and
1127 the latter lets you visually mark/unmark rows by clicking on them.
1128 See themes/themename/layout.inc.php.
1129 $cfg['FontFamily'] string
1130 You put here a valid CSS font family value, for example arial, sans-serif.
1131 See themes/themename/layout.inc.php.
1132 $cfg['FontFamilyFixed'] string
1133 You put here a valid CSS font family value, for example monospace. This one
1134 is used in textarea.
1135 See themes/themename/layout.inc.php.
1136 $cfg['BrowsePointerEnable'] boolean
1137 Whether to activate the browse pointer or not.
1138 $cfg['BrowseMarkerEnable'] boolean
1139 Whether to activate the browse marker or not.
1140 $cfg['TextareaCols'] integer
1141 $cfg['TextareaRows'] integer
1142 $cfg['CharTextareaCols'] integer
1143 $cfg['CharTextareaRows'] integer
1144 Number of columns and rows for the textareas.
1145 This value will be emphasized (*2) for SQL query textareas and (*1.25) for
1146 SQL textareas inside the query window.
1147 The Char* values are used for CHAR and VARCHAR editing (if configured via
1148 $cfg['CharEditing']).
1149 $cfg['LongtextDoubleTextarea'] boolean
1150 Defines whether textarea for LONGTEXT fields should have double size.
1151 $cfg['TextareaAutoSelect'] boolean
1152 Defines if the whole textarea of the query box will be selected on click.
1153 $cfg['CtrlArrowsMoving'] boolean
1154 Enable Ctrl+Arrows (Option+Arrows in Safari) moving between fields when
1156 $cfg['LimitChars'] integer
1157 Maximum number of characters showen in any non-numeric field on browse
1158 view. Can be turned off by a toggle button on the browse page.
1159 $cfg['ModifyDeleteAtLeft'] boolean $cfg['ModifyDeleteAtRight'] boolean
1160 Defines the place where modify and delete links would be put when tables
1161 contents are displayed (you may have them displayed both at the left and at
1162 the right). "Left" and "right" are parsed as "top" and "bottom" with
1163 vertical display mode.
1164 $cfg['DefaultDisplay'] string $cfg['HeaderFlipType'] string
1165 There are 3 display modes: horizontal, horizontalflipped and vertical.
1166 Define which one is displayed by default. The first mode displays each row
1167 on a horizontal line, the second rotates the headers by 90 degrees, so you
1168 can use descriptive headers even though fields only contain small values
1169 and still print them out. The vertical mode sorts each row on a vertical
1172 The HeaderFlipType can be set to 'css' or 'fake'. When using 'css' the
1173 rotation of the header for horizontalflipped is done via CSS. If set to
1174 'fake' PHP does the transformation for you, but of course this does not
1175 look as good as CSS.
1176 $cfg['DefaultPropDisplay'] string or integer
1177 When editing/creating new columns in a table all fields normally get lined
1178 up one field a line. (default: 'horizontal'). If you set this to 'vertical'
1179 you can have each field lined up vertically beneath each other. You can
1180 save up a lot of place on the horizontal direction and no longer have to
1181 scroll. If you set this to integer, editing of fewer columns will appear in
1182 'vertical' mode, while editing of more fields still in 'horizontal' mode.
1183 This way you can still effectively edit large number of fields, while
1184 having full view on few of them.
1185 $cfg['ShowBrowseComments'] boolean
1186 $cfg['ShowPropertyComments'] boolean
1187 By setting the corresponding variable to TRUE you can enable the display of
1188 column comments in Browse or Property display. In browse mode, the comments
1189 are shown inside the header. In property mode, comments are displayed using
1190 a CSS-formatted dashed-line below the name of the field. The comment is
1191 shown as a tool-tip for that field.
1192 $cfg['SQLQuery']['Edit'] boolean
1193 Whether to display an edit link to change a query in any SQL Query box.
1194 $cfg['SQLQuery']['Explain'] boolean
1195 Whether to display a link to explain a SELECT query in any SQL Query box.
1196 $cfg['SQLQuery']['ShowAsPHP'] boolean
1197 Whether to display a link to wrap a query in PHP code in any SQL Query box.
1198 $cfg['SQLQuery']['Validate'] boolean
1199 Whether to display a link to validate a query in any SQL Query box. See
1200 also $cfg_SQLValidator.
1201 $cfg['SQLQuery']['Refresh'] boolean
1202 Whether to display a link to refresh a query in any SQL Query box.
1203 $cfg['UploadDir'] string
1204 The name of the directory where SQL files have been uploaded by other means
1205 than phpMyAdmin (for example, ftp). Those files are available under a
1206 drop-down box when you click the database or table name, then the Import
1209 If you want different directory for each user, %u will be replaced with
1212 Please note that the file names must have the suffix ".sql" (or ".sql.bz2"
1213 or ".sql.gz" if support for compressed formats is enabled).
1215 This feature is useful when your file is too big to be uploaded via HTTP,
1216 or when file uploads are disabled in PHP.
1218 Please note that if PHP is running in safe mode, this directory must be
1219 owned by the same user as the owner of the phpMyAdmin scripts.
1221 See also FAQ 1.16 for alternatives.
1222 $cfg['SaveDir'] string
1223 The name of the directory where dumps can be saved.
1225 If you want different directory for each user, %u will be replaced with
1228 Please note that the directory must exist and has to be writable for the
1229 user running the webserver.
1231 Please note that if PHP is running in safe mode, this directory must be
1232 owned by the same user as the owner of the phpMyAdmin scripts.
1233 $cfg['TempDir'] string
1234 The name of the directory where temporary files can be stored.
1236 This is needed for native MS Excel export, see FAQ 6.23
1237 $cfg['Export'] array
1238 In this array are defined default parameters for export, names of items are
1239 similar to texts seen on export page, so you can easily identify what they
1241 $cfg['Import'] array
1242 In this array are defined default parameters for import, names of items are
1243 similar to texts seen on import page, so you can easily identify what they
1245 $cfg['RepeatCells'] integer
1246 Repeat the headers every X cells, or 0 to deactivate.
1247 $cfg['EditInWindow'] boolean
1248 $cfg['QueryWindowWidth'] integer
1249 $cfg['QueryWindowHeight'] integer
1250 $cfg['QueryHistoryDB'] boolean
1251 $cfg['QueryWindowDefTab'] string
1252 $cfg['QueryHistoryMax'] integer
1253 All those variables affect the query window feature. A SQL link or icon is
1254 always displayed on the left panel. If JavaScript is enabled in your
1255 browser, a click on this opens a distinct query window, which is a direct
1256 interface to enter SQL queries. Otherwise, the right panel changes to
1257 display a query box.
1259 The size of this query window can be customized with $cfg
1260 ['QueryWindowWidth'] and $cfg['QueryWindowWidth'] - both integers for the
1261 size in pixels. Note that normally, those parameters will be modified in
1262 layout.inc.php for the theme you are using.
1264 If $cfg['EditInWindow'] is set to true, a click on [Edit] from the results
1265 page (in the "Showing Rows" section) opens the query window and puts the
1266 current query inside it. If set to false, clicking on the link puts the SQL
1267 query in the right panel's query box.
1269 The usage of the JavaScript query window is recommended if you have a
1270 JavaScript enabled browser. Basic functions are used to exchange quite a
1271 few variables, so most 4th generation browsers should be capable to use
1272 that feature. It currently is only tested with Internet Explorer 6 and
1275 If $cfg['QueryHistoryDB'] is set to TRUE, all your Queries are logged to a
1276 table, which has to be created by you (see $cfg['Servers'][$i]['history']).
1277 If set to FALSE, all your queries will be appended to the form, but only as
1278 long as your window is opened they remain saved.
1280 When using the JavaScript based query window, it will always get updated
1281 when you click on a new table/db to browse and will focus if you click on
1282 "Edit SQL" after using a query. You can suppress updating the query window
1283 by checking the box "Do not overwrite this query from outside the window"
1284 below the query textarea. Then you can browse tables/databases in the
1285 background without losing the contents of the textarea, so this is
1286 especially useful when composing a query with tables you first have to look
1287 in. The checkbox will get automatically checked whenever you change the
1288 contents of the textarea. Please uncheck the button whenever you definitely
1289 want the query window to get updated even though you have made alterations.
1291 If $cfg['QueryHistoryDB'] is set to TRUE you can specify the amount of
1292 saved history items using $cfg['QueryHistoryMax'].
1294 The query window also has a custom tabbed look to group the features. Using
1295 the variable $cfg['QueryWindowDefTab'] you can specify the default tab to
1296 be used when opening the query window. It can be set to either 'sql',
1297 'files', 'history' or 'full'.
1298 $cfg['BrowseMIME'] boolean
1299 Enable MIME-transformations.
1300 $cfg['MaxExactCount'] integer
1301 For InnoDB tables, determines for how large tables phpMyAdmin should get
1302 the exact row count using SELECT COUNT. If the approximate row count as
1303 returned by SHOW TABLE STATUS is smaller than this value, SELECT COUNT will
1304 be used, otherwise the approximate count will be used.
1305 $cfg['MaxExactCountViews'] integer
1306 For VIEWs, since obtaining the exact count could have an impact on
1307 performance, this value is the maximum to be displayed, using a SELECT
1308 COUNT ... LIMIT. The default value of 0 bypasses any row counting.
1309 $cfg['WYSIWYG-PDF'] boolean
1310 Utilizes a WYSIWYG editing control to easily place elements of a PDF page.
1311 By clicking on the button 'toggle scratchboard' on the page where you edit
1312 x/y coordinates of those elements you can activate a scratchboard where all
1313 your elements are placed. By clicking on an element, you can move them
1314 around in the pre-defined area and the x/y coordinates will get updated
1315 dynamically. Likewise, when entering a new position directly into the input
1316 field, the new position in the scratchboard changes after your cursor
1317 leaves the input field.
1318 You have to click on the 'OK'-button below the tables to save the new
1319 positions. If you want to place a new element, first add it to the table of
1320 elements and then you can drag the new element around.
1321 By changing the paper size and the orientation you can change the size of
1322 the scratchboard as well. You can do so by just changing the dropdown field
1323 below, and the scratchboard will resize automatically, without interfering
1324 with the current placement of the elements.
1325 If ever an element gets out of range you can either enlarge the paper size
1326 or click on the 'reset' button to place all elements below each other.
1327 NOTE: You have to use a recent browser like IE6 or Mozilla to get this
1328 control to work. The basic Drag&Drop script functionality was kindly
1329 borrowed from www.youngpup.net and is underlying so specific license.
1330 $cfg['NaturalOrder'] boolean
1331 Sorts database and table names according to natural order (for example, t1,
1332 t2, t10). Currently implemented in the left panel (Light mode) and in
1333 Database view, for the table list.
1334 $cfg['TitleTable'] string
1335 $cfg['TitleDatabase'] string
1336 $cfg['TitleServer'] string
1337 $cfg['TitleDefault'] string
1338 Allows you to specify window's title bar. Following magic string can be
1339 used to get special values:
1342 HTTP host that runs phpMyAdmin
1346 Verbose MySQL server name as defined in server configuration
1348 Verbose MySQL server name if set, otherwise normal
1350 Currently opened database
1352 Currently opened table
1354 phpMyAdmin with version
1356 $cfg['ErrorIconic'] boolean
1357 Uses icons for warnings, errors and informations.
1358 $cfg['MainPageIconic'] boolean
1359 Uses icons on main page in lists and menu tabs.
1360 $cfg['ReplaceHelpImg'] boolean
1361 Shows a help button instead of the "Documentation" message.
1362 $cfg['ThemePath'] string
1363 If theme manager is active, use this as the path of the subdirectory
1364 containing all the themes.
1365 $cfg['ThemeManager'] boolean
1366 Enables user-selectable themes. See FAQ 2.7.
1367 $cfg['ThemeDefault'] string
1368 The default theme (a subdirectory under cfg['ThemePath']).
1369 $cfg['ThemePerServer'] boolean
1370 Whether to allow different theme for each server.
1371 $cfg['DefaultQueryTable'] string
1372 $cfg['DefaultQueryDatabase'] string
1373 Default queries that will be displayed in query boxes when user didn't
1374 specify any. Use %d for database name, %t for table name and %f for a comma
1375 separated list of field names. Note that %t and %f are only applicable to
1376 $cfg['DefaultQueryTable'].
1377 $cfg['SQP']['fmtType'] string [html|none]
1378 The main use of the new SQL Parser is to pretty-print SQL queries. By
1379 default we use HTML to format the query, but you can disable this by
1380 setting this variable to 'none'.
1381 $cfg['SQP']['fmtInd'] float
1382 $cfg['SQP']['fmtIndUnit'] string [em|px|pt|ex]
1383 For the pretty-printing of SQL queries, under some cases the part of a
1384 query inside a bracket is indented. By changing $cfg['SQP']['fmtInd'] you
1385 can change the amount of this indent.
1386 Related in purpose is $cfg['SQP']['fmtIndUnit'] which specifies the units
1387 of the indent amount that you specified. This is used via stylesheets.
1388 $cfg['SQP']['fmtColor'] array of string tuples
1389 This array is used to define the colours for each type of element of the
1390 pretty-printed SQL queries. The tuple format is
1391 class => [HTML colour code | empty string]
1392 If you specify an empty string for the color of a class, it is ignored in
1393 creating the stylesheet. You should not alter the class names, only the
1396 + comment Applies to all comment sub-classes
1397 + comment_mysql Comments as "#...\n"
1398 + comment_ansi Comments as "-- ...\n"
1399 + comment_c Comments as "/*...*/"
1400 + digit Applies to all digit sub-classes
1401 + digit_hex Hexadecimal numbers
1402 + digit_integer Integer numbers
1403 + digit_float Floating point numbers
1404 + punct Applies to all punctuation sub-classes
1405 + punct_bracket_open_round Opening brackets"("
1406 + punct_bracket_close_round Closing brackets ")"
1407 + punct_listsep List item Separator ","
1408 + punct_qualifier Table/Column Qualifier "."
1409 + punct_queryend End of query marker ";"
1410 + alpha Applies to all alphabetic classes
1411 + alpha_columnType Identifiers matching a column type
1412 + alpha_columnAttrib Identifiers matching a database/table/column
1414 + alpha_functionName Identifiers matching a MySQL function name
1415 + alpha_reservedWord Identifiers matching any other reserved word
1416 + alpha_variable Identifiers matching a SQL variable "@foo"
1417 + alpha_identifier All other identifiers
1418 + quote Applies to all quotation mark classes
1419 + quote_double Double quotes "
1420 + quote_single Single quotes '
1421 + quote_backtick Backtick quotes `
1422 $cfg['SQLValidator'] boolean
1424 $cfg['SQLValidator']['use'] boolean
1425 phpMyAdmin now supports use of the Mimer SQL Validator service, as
1426 originally published on Slashdot.
1427 For help in setting up your system to use the service, see the FAQ 6.14
1429 $cfg['SQLValidator']['username'] string
1430 $cfg['SQLValidator']['password'] string
1431 The SOAP service allows you to log in with anonymous and any password,
1432 so we use those by default. Instead, if you have an account with them,
1433 you can put your login details here, and it will be used in place of
1434 the anonymous login.
1438 $cfg['DBG']['enable'] boolean
1440 Enable the DBG extension for debugging phpMyAdmin. Required for profiling
1442 For help in setting up your system to this, see the Developers section.
1443 $cfg['DBG']['profile']['enable'] boolean
1445 Enable profiling support for phpMyAdmin. This will append a chunk of data
1446 to the end of every page displayed in the main window with profiling
1447 statistics for that page.
1448 You may need to increase the maximum execution time for this to complete
1449 successfully.Profiling was removed from the code for version 2.9.0 due to
1451 $cfg['DBG']['profile']['threshold'] float (units in milliseconds)
1453 When profiling data is displayed, this variable controls the threshold of
1454 display for any profiling data, based on the average time each time has
1455 taken. If it is over the threshold it is displayed, otherwise it is not
1456 displayed. This takes a value in milliseconds. In most cases you don't need
1458 $cfg['ColumnTypes'] array
1459 All possible types of a MySQL column. In most cases you don't need to edit
1461 $cfg['AttributeTypes'] array
1462 Possible attributes for fields. In most cases you don't need to edit this.
1463 $cfg['Functions'] array
1464 A list of functions MySQL supports. In most cases you don't need to edit
1466 $cfg['RestrictColumnTypes'] array
1467 Mapping of column types to meta types used for preferring displayed
1468 functions. In most cases you don't need to edit this.
1469 $cfg['RestrictFunctions'] array
1470 Functions preferred for column meta types as defined in $cfg
1471 ['RestrictColumnTypes']. In most cases you don't need to edit this.
1472 $cfg['DefaultFunctions'] array
1473 Functions selected by default when inserting/changing row, Functions are
1474 defined for meta types from $cfg['RestrictColumnTypes'] and for
1475 first_timestamp, which is used for first timestamp column in table.
1476 $cfg['NumOperators'] array
1477 Operators available for search operations on numeric and date fields.
1478 $cfg['TextOperators'] array
1479 Operators available for search operations on character fields. Note that we
1480 put LIKE by default instead of LIKE %...%, to avoid unintended performance
1481 problems in case of huge tables.
1482 $cfg['EnumOperators'] array
1483 Operators available for search operations on enum fields.
1484 $cfg['NullOperators'] array
1485 Additional operators available for search operations when the field can be
1496 To enable transformations, you have to setup the column_info table and the
1497 proper directives. Please see the Configuration section on how to do so.
1499 You can apply different transformations to the contents of each field. The
1500 transformation will take the content of each field and transform it with
1501 certain rules defined in the selected transformation.
1503 Say you have a field 'filename' which contains a filename. Normally you would
1504 see in phpMyAdmin only this filename. Using transformations you can transform
1505 that filename into a HTML link, so you can click inside of the phpMyAdmin
1506 structure on the field's link and will see the file displayed in a new browser
1507 window. Using transformation options you can also specify strings to append/
1508 prepend to a string or the format you want the output stored in.
1510 For a general overview of all available transformations and their options, you
1511 can consult your <www.your-host.com>/<your-install-dir>/
1512 transformation_overview.php installation.
1514 For a tutorial on how to effectively use transformations, see our Link section
1515 on the official phpMyAdmin homepage.
1519 Go to your tbl_structure.php page (i.e. reached through clicking on the
1520 'Structure' link for a table). There click on "Change" (or change icon) and
1521 there you will see three new fields at the end of the line. They are called
1522 'MIME-type', 'Browser transformation' and 'Transformation options'.
1524 * The field 'MIME-type' is a drop-down field. Select the MIME-type that
1525 corresponds to the column's contents. Please note that transformations are
1526 inactive as long as no MIME-type is selected.
1527 * The field 'Browser transformation' is a drop-down field. You can choose
1528 from a hopefully growing amount of pre-defined transformations. See below
1529 for information on how to build your own transformation.
1530 There are global transformations and mimetype-bound transformations. Global
1531 transformations can be used for any mimetype. They will take the mimetype,
1532 if necessary, into regard. Mimetype-bound transformations usually only
1533 operate on a certain mimetype. There are transformations which operate on
1534 the main mimetype (like 'image'), which will most likely take the subtype
1535 into regard, and those who only operate on a specific subtype (like 'image/
1537 You can use transformations on mimetypes for which the function was not
1538 defined for. There is no security check for you selected the right
1539 transformation, so take care of what the output will be like.
1540 * The field 'Transformation options' is a free-type textfield. You have to
1541 enter transform-function specific options here. Usually the transforms can
1542 operate with default options, but it is generally a good idea to look up
1543 the overview to see which options are necessary.
1544 Much like the ENUM/SET-Fields, you have to split up several options using
1545 the format 'a','b','c',...(NOTE THE MISSING BLANKS). This is because
1546 internally the options will be parsed as an array, leaving the first value
1547 the first element in the array, and so forth.
1548 If you want to specify a MIME character set you can define it in the
1549 transformation_options. You have to put that outside of the pre-defined
1550 options of the specific mime-transform, as the last value of the set. Use
1551 the format "'; charset=XXX'". If you use a transform, for which you can
1552 specify 2 options and you want to append a character set, enter "'first
1553 parameter','second parameter','charset=us-ascii'". You can, however use the
1554 defaults for the parameters: "'','','charset=us-ascii'".
1558 All mimetypes and their transformations are defined through single files in the
1559 directory 'libraries/transformations/'.
1561 They are stored in files to ease up customization and easy adding of new
1564 Because the user cannot enter own mimetypes, it is kept sure that
1565 transformations always work. It makes no sense to apply a transformation to a
1566 mimetype, the transform-function doesn't know to handle.
1568 One can, however, use empty mime-types and global transformations which should
1569 work for many mimetypes. You can also use transforms on a different mimetype
1570 they where built for, but pay attention to option usage as well as what the
1571 transformation does to your field.
1573 There is a basic file called 'global.inc.php'. This function can be included by
1574 any other transform function and provides some basic functions.
1576 There are 5 possible file names:
1578 1. A mimetype+subtype transform:
1580 [mimetype]_[subtype]__[transform].inc.php
1582 Please not that mimetype and subtype are separated via '_', which shall not
1583 be contained in their names. The transform function/filename may contain
1584 only characters which cause no problems in the file system as well as the
1585 PHP function naming convention.
1587 The transform function will the be called 'PMA_transform_[mimetype]_
1588 [subtype]__[transform]()'.
1592 text_html__formatted.inc.php
1593 PMA_transform_text_html__formatted()
1594 2. A mimetype (w/o subtype) transform:
1596 [mimetype]__[transform].inc.php
1598 Please note that there are no single '_' characters. The transform function
1599 /filename may contain only characters which cause no problems in the file
1600 system as well as the PHP function naming convention.
1602 The transform function will the be called 'PMA_transform_[mimetype]__
1607 text__formatted.inc.php
1608 PMA_transform_text__formatted()
1609 3. A mimetype+subtype without specific transform function
1611 [mimetype]_[subtype].inc.php
1613 Please note that there are no '__' characters in the filename. Do not use
1614 special characters in the filename causing problems with the file system.
1616 No transformation function is defined in the file itself.
1622 4. A mimetype (w/o subtype) without specific transform function
1626 Please note that there are no '_' characters in the filename. Do not use
1627 special characters in the filename causing problems with the file system.
1629 No transformation function is defined in the file itself.
1635 5. A global transform function with no specific mimetype
1637 global__[transform].inc.php
1639 The transform function will the be called 'PMA_transform_global__
1645 PMA_transform_global__formatted()
1647 So generally use '_' to split up mimetype and subtype, and '__' to provide a
1650 All filenames containing no '__' in themselves are not shown as valid transform
1651 functions in the dropdown.
1653 Please see the libraries/transformations/TEMPLATE file for adding your own
1654 transform function. See the libraries/transformations/TEMPLATE_MIMETYPE for
1655 adding a mimetype without a transform function. Also note the introduction of a
1656 function description in the language files. For each function a
1657 $strTransformation_[filename without .inc.php] has to exist.
1659 You can use the template generator to generate new functions and entries in the
1662 To create a new transform function please see libraries/transformations/
1663 template_generator.sh. To create a new, empty mimetype please see libraries/
1664 transformations/template_generator_mimetype.sh.
1666 A transform function always gets passed three variables:
1668 1. $buffer - Contains the text inside of the column. This is the text, you
1670 2. $options - Contains any user-passed options to a transform function as an
1672 3. $meta - Contains an object with field information to your column. The data
1673 is drawn from the output of the mysql_fetch_field() function. This means,
1674 all object properties described on the manual page are available in this
1675 variable and can be used to transform a field accordingly to unsigned/
1676 zerofill/not_null/... properties.
1677 The $meta->mimetype variable contains the original MIME-type of the field
1678 (i.e. 'text/plain', 'image/jpeg' etc.)
1680 FAQ - Frequently Asked Questions
1684 3. Known limitations
1685 4. ISPs, multi-user installations
1686 5. Browsers or client OS
1688 7. phpMyAdmin project
1691 Please have a look at our Link section on the official phpMyAdmin homepage for
1692 in-depth coverage of phpMyAdmin's features and or interface.
1696 1.1 I'm running PHP 4+ and my server is crashing each time a specific action is
1697 required or phpMyAdmin sends a blank page or a page full of cryptic characters
1698 to my browser, what can I do?
1700 There are some known PHP bugs with output buffering and compression.
1701 Try to set the $cfg['OBGzip'] directive to FALSE in your config.inc.php file
1702 and the zlib.output_compression directive to Off in your php configuration
1704 Furthermore, we know about such problems connected to the release candidates of
1705 PHP 4.2.0 (tested with PHP 4.2.0 RC1 to RC4) together with MS Internet
1706 Explorer. Please upgrade to the release version PHP 4.2.0.
1708 1.2 My Apache server crashes when using phpMyAdmin.
1710 You should first try the latest versions of Apache (and possibly MySQL).
1711 See also the FAQ 1.1 entry about PHP bugs with output buffering.
1712 If your server keeps crashing, please ask for help in the various Apache
1715 1.3 I'm running phpMyAdmin with "cookie" authentication mode under PHP 4.2.0 or
1716 4.2.1 loaded as an Apache 2 module but can't enter the script: I'm always
1717 displayed the login screen.
1719 This is a known PHP bug (see this bug report) from the official PHP bug
1720 database. It means there is and won't be any phpMyAdmin fix against it because
1721 there is no way to code a fix.
1723 1.4 Using phpMyAdmin on IIS, I'm displayed the error message: "The specified
1724 CGI application misbehaved by not returning a complete set of HTTP headers
1727 You just forgot to read the install.txt file from the php distribution. Have a
1728 look at the last message in this bug report from the official PHP bug database.
1730 1.5 Using phpMyAdmin on IIS, I'm facing crashes and/or many error messages with
1731 the HTTP or advanced authentication mode.
1733 This is a known problem with the PHP ISAPI filter: it's not so stable. Please
1734 use instead the cookie authentication mode.
1736 1.6 I can't use phpMyAdmin on PWS: nothing is displayed!
1738 This seems to be a PWS bug. Filippo Simoncini found a workaround (at this time
1739 there is no better fix): remove or comment the DOCTYPE declarations (2 lines)
1740 from the scripts libraries/header.inc.php, libraries/header_printview.inc.php,
1741 index.php, navigation.php and libraries/common.lib.php.
1743 1.7 How can I GZip or Bzip a dump or a CSV export? It does not seem to work.
1745 These features are based on the gzencode() and bzcompress() PHP functions to be
1746 more independent of the platform (Unix/Windows, Safe Mode or not, and so on).
1747 So, you must have PHP4 >= 4.0.4 and Zlib/Bzip2 support (--with-zlib and
1749 We faced PHP crashes when trying to download a dump with MS Internet Explorer
1750 when phpMyAdmin is run with a release candidate of PHP 4.2.0. In this case you
1751 should switch to the release version of PHP 4.2.0.
1753 1.8 I cannot insert a text file in a table, and I get an error about safe mode
1756 Your uploaded file is saved by PHP in the "upload dir", as defined in php.ini
1757 by the variable upload_tmp_dir (usually the system default is /tmp).
1758 We recommend the following setup for Apache servers running in safe mode, to
1759 enable uploads of files while being reasonably secure:
1761 * create a separate directory for uploads: mkdir /tmp/php
1762 * give ownership to the Apache server's user.group: chown apache.apache /tmp/
1764 * give proper permission: chmod 600 /tmp/php
1765 * put upload_tmp_dir = /tmp/php in php.ini
1768 1.9 I'm having troubles when uploading files. In general file uploads don't
1769 work on my system and uploaded files have a Content-Type: header in the first
1772 It's not really phpMyAdmin related but RedHat 7.0. You have a RedHat 7.0 and
1773 you updated your PHP RPM to php-4.0.4pl1-3.i386.rpm, didn't you?
1774 So the problem is that this package has a serious bug that was corrected ages
1775 ago in PHP (2001-01-28: see PHP's bug tracking system for more details). The
1776 problem is that the bugged package is still available though it was corrected
1777 (see RedHat's BugZilla for more details).
1778 So please download the fixed package (4.0.4pl1-9) and the problem should go
1780 And that fixes the \r\n problem with file uploads!
1782 1.10 I'm having troubles when uploading files with phpMyAdmin running on a
1783 secure server. My browser is Internet Explorer and I'm using the Apache server.
1785 As suggested by "Rob M" in the phpWizard forum, add this line to your
1788 SetEnvIf User-Agent ".*MSIE.*" nokeepalive ssl-unclean-shutdown
1790 It seems to clear up many problems between Internet Explorer and SSL.
1792 1.11 I get an 'open_basedir restriction' while uploading a file from the query
1795 Since version 2.2.4, phpMyAdmin supports servers with open_basedir
1796 restrictions. Assuming that the restriction allows you to open files in the
1797 current directory ('.'), all you have to do is create a 'tmp' directory under
1798 the phpMyAdmin install directory, with permissions 777 and the same owner as
1799 the owner of your phpMyAdmin directory. The uploaded files will be moved there,
1800 and after execution of your SQL commands, removed.
1802 1.12 I have lost my MySQL root password, what can I do?
1804 The MySQL manual explains how to reset the permissions.
1806 1.13 I get an error 'No SQL query' when trying to execute a bookmark.
1808 If PHP does not have read/write access to its upload_tmp_dir, it cannot access
1811 1.14 I get an error 'No SQL query' when trying to submit a query from the
1812 convenient text area.
1814 Check the post_max_size directive from your PHP configuration file and try to
1817 1.15 I have problems with mysql.user field names.
1819 In previous MySQL versions, the User and Password fields were named user and
1820 password. Please modify your field names to align with current standards.
1822 1.16 I cannot upload big dump files (memory, HTTP or timeout problems).
1824 Starting with version 2.7.0, the import engine has been re?written and these
1825 problems should not occur. If possible, upgrade your phpMyAdmin to the latest
1826 version to take advantage of the new import features.
1828 The first things to check (or ask your host provider to check) are the values
1829 of upload_max_filesize, memory_limit and post_max_size in the php.ini
1830 configuration file. All of these three settings limit the maximum size of data
1831 that can be submitted and handled by PHP. One user also said that post_max_size
1832 and memory_limit need to be larger than upload_max_filesize.
1834 There exist several workarounds if your upload is too big or your hosting
1835 provider is unwilling to change the settings:
1837 * Look at the $cfg['UploadDir'] feature. This allows one to upload a file to
1838 the server via scp, ftp, or your favorite file transfer method. PhpMyAdmin
1839 is then able to import the files from the temporary directory. More
1840 information is available in the Configuration section of this document.
1841 * Using a utility (such as BigDump) to split the files before uploading. We
1842 cannot support this or any third party applications, but are aware of users
1843 having success with it.
1844 * If you have shell (command line) access, use MySQL to import the files
1845 directly. You can do this by issuing the "source" command from within
1846 MySQL: source filename.sql.
1848 1.17 Which MySQL versions does phpMyAdmin support?
1850 All MySQL versions from 3.23.32 till 5.0 (except for 4.1.0 and 4.1.1) are fully
1851 supported. Please note that the older your MySQL version is, the more
1852 limitations you will have to face.
1853 phpMyAdmin may connect to your MySQL server using php's classic MySQL extension
1854 as well as the improved MySQL extension (MySQLi) that is available in php 5.0.
1855 Either way, the developers of both extensions recommend to use the classic
1856 extension for MySQL 4.0 and below and MySQLi for MySQL 4.1 and newer.
1857 When compiling php, we strongly recommend that you manually link the MySQL
1858 extension of your choice to a MySQL client library of at least the same minor
1859 version since the one that is bundled with some php distributions is rather old
1860 and might cause problems (see FAQ 1.17a). If your webserver is running on a
1861 windows system, you might want to try MySQL's Connector/PHP instead of the
1862 MySQL / MySQLi extensions that are bundled with the official php Win32 builds.
1863 MySQL 5.1 is not yet supported.
1865 1.17a I cannot connect to the MySQL server. It always returns the error
1866 message, "Client does not support authentication protocol requested by server;
1867 consider upgrading MySQL client"
1869 You tried to access MySQL with an old MySQL client library. The version of your
1870 MySQL client library can be checked in your phpinfo() output. In general, it
1871 should have at least the same minor version as your server - as mentioned in
1874 This problem is generally caused by using MySQL version 4.1 or newer. MySQL
1875 changed the authentication hash and your PHP is trying to use the old method.
1876 The proper solution is to use the mysqli extension with the proper client
1877 library to match your MySQL installation. Your chosen extension is specified in
1878 $cfg['Servers'][$i]['extension']. More information (and several workarounds)
1879 are located in the MySQL Documentation.
1881 1.18 I'm running MySQL <= 4.0.1 having lower_case_table_names set to 1. If I
1882 create a new table with a capital letter in its name it is changed to lowercase
1883 as it should. But if I try to DROP this table MySQL is unable to find the
1886 This is a bug of MySQL <= 4.0.1. Please upgrade to at least MySQL 4.0.2 or turn
1887 off your lower_case_table_names directive.
1889 1.19 I can't run the "display relations" feature because the script seems not
1890 to know the font face I'm using!
1892 The "FPDF" library we're using for this feature requires some special files to
1894 Please refers to the FPDF manual to build these files.
1896 1.20 I receive the error "cannot load MySQL extension, please check PHP
1899 To connect to a MySQL server, PHP needs a set of MySQL functions called "MySQL
1900 extension". This extension may be part of the PHP distribution (compiled-in),
1901 otherwise it needs to be loaded dynamically. Its name is probably mysql.so or
1902 php_mysql.dll. phpMyAdmin tried to load the extension but failed.
1904 Usually, the problem is solved by installing a software package called
1905 "PHP-MySQL" or something similar.
1907 1.21 I am running the CGI version of PHP under Unix, and I cannot log in using
1910 In php.ini, set mysql.max_links higher than 1.
1912 1.22 I don't see the "Location of text file" field, so I cannot upload.
1914 This is most likely because in php.ini, your file_uploads parameter is not set
1917 1.23 I'm running MySQL on a Win32 machine. Each time I create a new table the
1918 table and field names are changed to lowercase!
1920 This happens because the MySQL directive lower_case_table_names defaults to 1
1921 (ON) in the Win32 version of MySQL. You can change this behavior by simply
1922 changing the directive to 0 (OFF):
1923 Just edit your my.ini file that should be located in your Windows directory and
1924 add the following line to the group [mysqld]:
1926 set-variable = lower_case_table_names=0
1928 Next, save the file and restart the MySQL service. You can always check the
1929 value of this directive using the query
1931 SHOW VARIABLES LIKE 'lower_case_table_names';
1933 1.24 Some characters are being truncated in my queries, or I get characters
1934 randomly added. I am running PHP 4.2.3.
1936 This is a PHP 4.2.3 bug.
1938 1.25 I am running Apache with mod_gzip-1.3.26.1a on Windows XP, and I get
1939 problems, such as undefined variables when I run a SQL query.
1941 A tip from Jose Fandos: put a comment on the following two lines in httpd.conf,
1944 # mod_gzip_item_include file \.php$
1945 # mod_gzip_item_include mime "application/x-httpd-php.*"
1947 as this version of mod_gzip on Apache (Windows) has problems handling PHP
1948 scripts. Of course you have to restart Apache.
1950 1.26 I just installed phpMyAdmin in my document root of IIS but I get the error
1951 "No input file specified" when trying to run phpMyAdmin.
1953 This is a permission problem. Right-click on the phpmyadmin folder and choose
1954 properties. Under the tab Security, click on "Add" and select the user
1955 "IUSR_machine" from the list. Now set his permissions and it should work.
1957 1.27 I get empty page when I want to view huge page (eg. db_structure.php with
1960 This is a PHP bug that occur when GZIP output buffering is enabled. If you turn
1961 off it (by $cfg['OBGzip'] = false in config.inc.php), it should work. This bug
1962 will be fixed in PHP 5.0.0.
1964 1.28 My MySQL server sometimes refuses queries and returns the message
1965 'Errorcode: 13'. What does this mean?
1967 This can happen due to a MySQL bug when having database / table names with
1968 upper case characters although lower_case_table_names is set to 1. To fix this,
1969 turn off this directive, convert all database and table names to lower case and
1970 turn it on again. Alternatively, there's a bug-fix available starting with
1971 MySQL 3.23.56 / 4.0.11-gamma.
1973 1.29 When I create a table or modify a field, I get an error and the fields are
1976 It is possible to configure Apache in such a way that PHP has problems
1977 interpreting .php files.
1979 The problems occur when two different (and conflicting) set of directives are
1987 AddType application/x-httpd-php .php
1989 In the case we saw, one set of directives was in /etc/httpd/conf/httpd.conf,
1990 while the other set was in /etc/httpd/conf/addon-modules/php.conf.
1991 The recommended way is with AddType, so just comment out the first set of lines
1994 #SetOutputFilter PHP
1997 1.30 I get the error "navigation.php: Missing hash".
1999 This problem is known to happen when the server is running Turck MMCache but
2000 upgrading MMCache to version 2.3.21 solves the problem.
2002 1.31 Does phpMyAdmin support php5?
2005 However, phpMyAdmin needs to be backwards compatible to php4. This is why
2006 phpMyAdmin disables the E_STRICT error_level in error_reporting settings.
2008 1.32 Can I use HTTP authentication with IIS?
2010 Yes. This procedure was tested with phpMyAdmin 2.6.1, PHP 4.3.9 in ISAPI mode
2013 1. In your php.ini file, set cgi.rfc2616_headers = 0
2014 2. In Web Site Properties -> File/Directory Security -> Anonymous Access
2015 dialog box, check the Anonymous access checkbox and uncheck any other
2016 checkboxes (i.e. uncheck Basic authentication, Integrated Windows
2017 authentication, and Digest if it's enabled.) Click OK.
2018 3. In Custom Errors, select the range of 401;1 through 401;5 and click the Set
2021 1.33 Is there a problem with the mysqli extension when running PHP 5.0.4 on
2024 Yes. This problem affects phpMyAdmin ("Call to undefined function
2025 pma_reloadnavigation"), so upgrade your PHP to the next version.
2027 1.34 Can I access directly to database or table pages?
2029 Yes. Out of the box, you can use URLs like http://server/phpMyAdmin/index.php?
2030 server=X&db=database&table=table&target=script. For server you use the server
2031 number which refers to the order of the server paragraph in config.inc.php.
2032 Table and script parts are optional. If you want http://server/phpMyAdmin/
2033 database[/table][/script] URLs, you need to do some configuration. Following
2034 lines apply only for Apache web server. First make sure, that you have enabled
2035 some features within global configuration. You need Options FollowSymLinks and
2036 AllowOverride FileInfo enabled for directory where phpMyAdmin is installed and
2037 you need mod_rewrite to be enabled. Then you just need to create following
2038 .htaccess file in root folder of phpMyAdmin installation (don't forget to
2039 change directory name inside of it):
2042 RewriteBase /path_to_phpMyAdmin
2043 RewriteRule ^([a-zA-Z0-9_]+)/([a-zA-Z0-9_]+)/([a-z_]+\.php)$ index.php?db=$1&table=$2&target=$3 [R]
2044 RewriteRule ^([a-zA-Z0-9_]+)/([a-z_]+\.php)$ index.php?db=$1&target=$2 [R]
2045 RewriteRule ^([a-zA-Z0-9_]+)/([a-zA-Z0-9_]+)$ index.php?db=$1&table=$2 [R]
2046 RewriteRule ^([a-zA-Z0-9_]+)$ index.php?db=$1 [R]
2048 1.35 Can I use HTTP authentication with Apache CGI?
2050 Yes. However you need to pass authentication variable to CGI using following
2054 RewriteRule .* - [E=REMOTE_USER:%{HTTP:Authorization},L]
2056 1.36 I get an error "500 Internal Server Error".
2058 There can be many explanations to this and a look at your server's error log
2059 file might give a clue.
2061 1.37 I run phpMyAdmin on cluster of different machines and password encryption
2062 in cookie auth doesn't work.
2064 If your cluster consist of different architectures, PHP code used for
2065 encryption/decryption won't work correct. This is caused by use of pack/unpack
2066 functions in code. Only solution is to use mcrypt extension which works fine in
2069 1.38 Can I use phpMyAdmin on a server on which Suhosin is enabled?
2071 Yes but the default configuration values of Suhosin are known to cause problems
2072 with some operations, for example editing a table with many columns and no
2073 primary key. Tuning information is available at http://www.hardened-php.net/
2074 hphp/troubleshooting.html, although the parameter names have changed (suhosin
2075 instead of hphp). See also the SuhosinDisableWarning directive.
2079 2.1 The error message "Warning: Cannot add header information - headers already
2080 sent by ..." is displayed, what's the problem?
2082 Edit your config.inc.php file and ensure there is nothing (I.E. no blank lines,
2083 no spaces, no characters...) neither before the <?php tag at the beginning,
2084 neither after the ?> tag at the end. We also got a report from a user under
2085 IIS, that used a zipped distribution kit: the file libraries/Config.class.php
2086 contained an end-of-line character (hex 0A) at the end; removing this character
2089 2.2 phpMyAdmin can't connect to MySQL. What's wrong?
2091 Either there is an error with your PHP setup or your username/password is
2092 wrong. Try to make a small script which uses mysql_connect and see if it works.
2093 If it doesn't, it may be you haven't even compiled MySQL support into PHP.
2095 2.3 The error message "Warning: MySQL Connection Failed: Can't connect to local
2096 MySQL server through socket '/tmp/mysql.sock' (111) ..." is displayed. What can
2099 For RedHat users, Harald Legner suggests this on the mailing list:
2101 On my RedHat-Box the socket of MySQL is /var/lib/mysql/mysql.sock. In your
2102 php.ini you will find a line
2104 mysql.default_socket = /tmp/mysql.sock
2108 mysql.default_socket = /var/lib/mysql/mysql.sock
2110 Then restart apache and it will work.
2112 Here is a fix suggested by Brad Ummer:
2114 * First, you need to determine what socket is being used by MySQL.
2115 To do this, telnet to your server and go to the MySQL bin directory. In
2116 this directory there should be a file named mysqladmin. Type ./mysqladmin
2117 variables, and this should give you a bunch of info about your MySQL
2118 server, including the socket (/tmp/mysql.sock, for example).
2119 * Then, you need to tell PHP to use this socket.
2120 To do this in phpMyAdmin, you need to complete the socket information in
2122 For example: $cfg['Servers'][$i]['socket'] = '/tmp/mysql.sock';
2124 Please also make sure that the permissions of this file allow to be
2125 readable by your webserver (i.e. '0755').
2127 Have also a look at the corresponding section of the MySQL documentation.
2129 2.4 Nothing is displayed by my browser when I try to run phpMyAdmin, what can I
2132 Try to set the $cfg['OBGZip'] directive to FALSE in the phpMyAdmin
2133 configuration file. It helps sometime.
2134 Also have a look at your PHP version number: if it contains "4.0b..." it means
2135 you're running a beta version of PHP. That's not a so good idea, please upgrade
2136 to a plain revision.
2138 2.5 Each time I want to insert or change a record or drop a database or a
2139 table, an error 404 (page not found) is displayed or, with HTTP or cookie
2140 authentication, I'm asked to log in again. What's wrong?
2142 Check the value you set for the $cfg['PmaAbsoluteUri'] directive in the
2143 phpMyAdmin configuration file.
2145 2.6 I get an "Access denied for user: 'root@localhost' (Using password: YES)
2146 "-error when trying to access a MySQL-Server on a host which is port-forwarded
2149 When you are using a port on your localhost, which you redirect via
2150 port-forwarding to another host, MySQL is not resolving the localhost as
2152 Erik Wasser explains: The solution is: if your host is "localhost" MySQL (the
2153 commandline tool 'mysql' as well) always tries to use the socket connection for
2154 speeding up things. And that doesn't work in this configuration with port
2156 If you enter "127.0.0.1" as hostname, everything is right and MySQL uses the
2159 2.7 Using and creating themes
2161 Themes are configured with $cfg['ThemePath'], $cfg['ThemeManager'] and $cfg
2164 Under $cfg['ThemePath'], you should not delete the directory "original" or its
2165 underlying structure, because this is the system theme used by phpMyAdmin.
2166 "original" contains all images and styles, for backwards compatibility and for
2167 all themes that would not include images or css-files.
2169 If $cfg['ThemeManager'] is enabled, you can select your favorite theme on the
2170 main page. Your selected theme will be stored in a cookie.
2175 * make a new subdirectory (for example "your_theme_name") under $cfg
2176 ['ThemePath'] (by default themes)
2177 * copy the files and directories from "original" to "your_theme_name"
2178 * edit the css-files in "your_theme_name/css"
2179 * put your new images in "your_theme_name/img"
2180 * edit layout.inc.php in "your_theme_name"
2181 * edit info.inc.php in "your_theme_name" to contain your chosen theme name,
2182 that will be visible in user interface
2183 * make a new screenshot of your theme and save it under "your_theme_name/
2186 In theme directory there is file info.inc.php which contains theme verbose
2187 name, theme generation and theme version. These versions and generations are
2188 enumerated from 1 and do not have any direct dependence on phpMyAdmin version.
2189 Themes within same generation should be backwards compatible - theme with
2190 version 2 should work in phpMyAdmin requiring version 1. Themes with different
2191 generation are incompatible.
2193 If you do not want to use your own symbols and buttons, remove the directory
2194 "img" in "your_theme_name". phpMyAdmin will use the default icons and buttons
2195 (from the system-theme "original").
2197 2.8 I get "Missing parameters" errors, what can I do?
2199 Here are a few points to check:
2201 * In config.inc.php, try to leave the $cfg['PmaAbsoluteUri'] directive empty.
2203 * Maybe you have a broken PHP installation or you need to upgrade your Zend
2204 Optimizer. See http://bugs.php.net/bug.php?id=31134.
2205 * If you are using Hardened PHP with the ini directive
2206 varfilter.max_request_variables set to the default (200) or another low
2207 value, you could get this error if your table has a high number of columns.
2208 Adjust this setting accordingly. (Thanks to Klaus Dorninger for the hint).
2209 * In the php.ini directive arg_separator.input, a value of ";" will cause
2210 this error. Replace it with "&;".
2211 * If you are using Hardened-PHP, you might want to increase request limits.
2212 * The directory specified in the php.ini directive session.save_path does not
2213 exist or is read-only.
2217 3.1 When using HTTP authentication, an user who logged out can not log in again
2218 in with the same nick.
2220 This is related to the authentication mechanism (protocol) used by phpMyAdmin.
2221 To bypass this problem: just close all the opened browser windows and then go
2222 back to phpMyAdmin. You should be able to log in again.
2224 3.2 When dumping a large table in compressed mode, I get a memory limit error
2225 or a time limit error.
2227 Compressed dumps are built in memory and because of this are limited to php's
2228 memory limit. For GZip/BZip2 exports this can be overcome since 2.5.4 using
2229 $cfg['CompressOnFly'] (enabled by default). Zip exports can not be handled this
2230 way, so if you need Zip files for larger dump, you have to use another way.
2232 3.3 With InnoDB tables, I lose foreign key relationships when I rename or alter
2235 This seems to be a InnoDB bug (fixed in MySQL 3.23.50?).
2237 3.4 I am unable to import dumps I created with the mysqldump tool bundled with
2238 the MySQL server distribution.
2240 The problem is that older versions of mysqldump created invalid comments like
2245 -- Host: localhost Database: database
2246 ---------------------------------------------------------
2247 -- Server version 3.23.54
2249 The invalid part of the code is the horizontal line made of dashes that appears
2250 once in every dump created with mysqldump. If you want to run your dump you
2251 have to turn it into valid MySQL. This means, you have to add a whitespace
2252 after the first two dashes of the line or add a # before it:
2253 -- -------------------------------------------------------
2255 #---------------------------------------------------------
2257 3.5 When using nested folders there are some multiple hierarchies displayed in
2258 a wrong manner?! ($cfg['LeftFrameTableSeparator'])
2260 Please note that you should not use the separating string multiple times
2261 without any characters between them, or at the beginning/end of your table
2262 name. If you have to, think about using another TableSeparator or disabling
2265 3.6 What is currently not supported in phpMyAdmin about InnoDB?
2267 In Relation view, being able to choose a table in another database, or having
2268 more than one index field in the foreign key.
2270 In Query-by-example (Query), automatic generation of the query LEFT JOIN from
2274 3.7 I have table with many (100+) fields and when I try to browse table I get
2275 series of errors like "Warning: unable to parse url". How can this be fixed?
2277 Your table neither have a primary key nor an unique one, so we must use a long
2278 expression to identify this row. This causes problems to parse_url function.
2279 The workaround is to create a primary or unique key.
2281 3.8 I cannot use (clickable) HTML-forms in fields where I put a
2282 MIME-Transformation onto!
2284 Due to a surrounding form-container (for multi-row delete checkboxes), no
2285 nested forms can be put inside the table where phpMyAdmin displays the results.
2286 You can, however, use any form inside of a table if keep the parent
2287 form-container with the target to tbl_row_delete.php and just put your own
2288 input-elements inside. If you use a custom submit input field, the form will
2289 submit itself to the displaying page again, where you can validate the
2290 $HTTP_POST_VARS in a transformation. For a tutorial on how to effectively use
2291 transformations, see our Link section on the official phpMyAdmin-homepage.
2293 3.9 I get error messages when using "--sql_mode=ANSI" for the MySQL server
2295 When MySQL is running in ANSI-compatibility mode, there are some major
2296 differences in how SQL is structured (see http://dev.mysql.com/doc/mysql/en/
2297 ANSI_mode.html). Most important of all, the quote-character (") is interpreted
2298 as an identifier quote character and not as a string quote character, which
2299 makes many internal phpMyAdmin operations into invalid SQL statements. There is
2300 no workaround to this behaviour. News to this item will be posted in Bug report
2303 3.10 Homonyms and no primary key: When the results of a SELECT display more
2304 that one column with the same value (for example SELECT lastname from employees
2305 where firstname like 'A%' and two "Smith" values are displayed), if I click
2306 Edit I cannot be sure that I am editing the intended row.
2308 Please make sure that your table has a primary key, so that phpMyAdmin can use
2309 it for the Edit and Delete links.
2311 3.11 The number of records for InnoDB tables is not correct.
2313 phpMyAdmin uses a quick method to get the row count, and this method only
2314 returns an approximate count in the case of InnoDB tables. See $cfg
2315 ['MaxExactCount'] for a way to modify those results, but this could have a
2316 serious impact on performance.
2318 3.12 What are the phpMyAdmin limitations for MySQL 3?
2320 The number of records in queries containing COUNT and GROUP BY is not correctly
2321 calculated. Also, sorting results of a query like "SELECT * from table GROUP
2322 BY" ... is problematic.
2324 3.13 I get an error when entering USE followed by a db name containing an
2327 The tests I have made with current MySQL 4.1.11 API shows that the API does not
2328 accept this syntax for the USE command. Enclosing the db name with backquotes
2329 works. For further confusion, no backquotes are needed with command-line mysql.
2331 3.14 I am not able to browse a table when I don't have the right to SELECT one
2334 This has been a known limitation of phpMyAdmin since the beginning and it's not
2335 likely to be solved in the future.
2337 ISPs, multi-user installations
2339 4.1 I'm an ISP. Can I setup one central copy of phpMyAdmin or do I need to
2340 install it for each customer.
2342 Since version 2.0.3, you can setup a central copy of phpMyAdmin for all your
2343 users. The development of this feature was kindly sponsored by NetCologne GmbH.
2344 This requires a properly setup MySQL user management and phpMyAdmin HTTP or
2345 cookie authentication. See the install section on "Using HTTP authentication".
2347 4.2 What's the preferred way of making phpMyAdmin secure against evil access.
2349 This depends on your system.
2350 If you're running a server which cannot be accessed by other people, it's
2351 sufficient to use the directory protection bundled with your webserver (with
2352 Apache you can use .htaccess files, for example).
2353 If other people have telnet access to your server, you should use phpMyAdmin's
2354 HTTP or cookie authentication features.
2358 * Your config.inc.php file should be chmod 660.
2359 * All your phpMyAdmin files should be chown -R phpmy.apache, where phpmy is a
2360 user whose password is only known to you, and apache is the group under
2362 * You should use PHP safe mode, to protect from other users that try to
2363 include your config.inc.php in their scripts.
2365 4.3 I get errors about not being able to include a file in /lang or in /
2368 Check php.ini, or ask your sysadmin to check it. The include_path must contain
2369 "." somewhere in it, and open_basedir, if used, must contain "." and "./lang"
2370 to allow normal operation of phpMyAdmin.
2372 4.4 phpMyAdmin always gives "Access denied" when using HTTP authentication.
2374 This could happen for several reasons:
2376 * $cfg['Servers'][$i]['controluser'] and/or $cfg['Servers'][$i]
2377 ['controlpass'] are wrong.
2378 * The username/password you specify in the login dialog are invalid.
2379 * You have already setup a security mechanism for the phpMyAdmin-directory,
2380 eg. a .htaccess file. This would interfere with phpMyAdmin's
2381 authentication, so remove it.
2383 4.5 Is it possible to let users create their own databases?
2385 Starting with 2.2.5, in the user management page, you can enter a wildcard
2386 database name for a user (for example "joe%"), and put the privileges you want.
2387 For example, adding SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, INDEX, ALTER
2388 would let a user create/manage his/her database(s).
2390 4.6 How can I use the Host-based authentication additions?
2392 If you have existing rules from an old .htaccess file, you can take them and
2393 add a username between the 'deny'/'allow' and 'from' strings. Using the
2394 username wildcard of '%' would be a major benefit here if your installation is
2395 suited to using it. Then you can just add those updated lines into the $cfg
2396 ['Servers'][$i]['AllowDeny']['rules'] array.
2398 If you want a pre-made sample, you can try this fragment. It stops the 'root'
2399 user from logging in from any networks other than the private network IP
2402 //block root from logging in except from the private networks
2403 $cfg['Servers'][$i]['AllowDeny']['order'] = 'deny,allow';
2404 $cfg['Servers'][$i]['AllowDeny']['rules'] = array(
2405 'deny root from all',
2406 'allow root from localhost',
2407 'allow root from 10.0.0.0/8',
2408 'allow root from 192.168.0.0/16',
2409 'allow root from 172.16.0.0/12',
2412 4.7 Authentication window is displayed more than once, why?
2414 This happens if you are using a URL to start phpMyAdmin which is different than
2415 the one set in your $cfg['PmaAbsoluteUri']. For example, a missing "www", or
2416 entering with an IP address while a domain name is defined in the config file.
2418 4.8 Which parameters can I use in the URL that starts phpMyAdmin?
2420 When starting phpMyAdmin, you can use the db, pma_username, pma_password and
2421 server parameters. This last one can contain either the numeric host index
2422 (from $i of the configuration file) or one of the host names present in the
2423 configuration file. Using pma_username and pma_password has been tested along
2424 with the usage of 'cookie' auth_type.
2426 Browsers or client OS
2428 5.1 I get an out of memory error, and my controls are non-functional, when
2429 trying to create a table with more than 14 fields.
2431 We could reproduce this problem only under Win98/98SE. Testing under WinNT4 or
2432 Win2K, we could easily create more than 60 fields.
2433 A workaround is to create a smaller number of fields, then come back to your
2434 table properties and add the other fields.
2436 5.2 With Xitami 2.5b4, phpMyAdmin won't process form fields.
2438 This is not a phpMyAdmin problem but a Xitami known bug: you'll face it with
2439 each script/website that use forms.
2440 Upgrade or downgrade your Xitami server.
2442 5.3 I have problems dumping tables with Konqueror (phpMyAdmin 2.2.2).
2444 With Konqueror 2.1.1: plain dumps, zip and GZip dumps work ok, except that the
2445 proposed file name for the dump is always 'tbl_dump.php'. Bzip2 dumps don't
2447 With Konqueror 2.2.1: plain dumps work; zip dumps are placed into the user's
2448 temporary directory, so they must be moved before closing Konqueror, or else
2449 they disappear. GZip dumps give an error message.
2450 Testing needs to be done for Konqueror 2.2.2.
2452 5.4 I can't use the cookie authentication mode because Internet Explorer never
2455 MS Internet Explorer seems to be really buggy about cookies, at least till
2456 version 6. And thanks to Andrew Zivolup we've traced also a PHP 4.1.1 bug in
2458 Then, if you're running PHP 4.1.1, try to upgrade or downgrade... it may work!
2460 5.5 In Internet Explorer 5.0, I get JavaScript errors when browsing my rows.
2462 Upgrade to at least Internet Explorer 5.5 SP2.
2464 5.6 In Internet Explorer 5.0, 5.5 or 6.0, I get an error (like "Page not
2465 found") when trying to modify a row in a table with many fields, or with a text
2468 Your table neither have a primary key nor an unique one, so we must use a long
2469 URL to identify this row. There is a limit on the length of the URL in those
2470 browsers, and this not happen in Netscape, for example. The workaround is to
2471 create a primary or unique key, or use another browser.
2473 5.7 I refresh (reload) my browser, and come back to the welcome page.
2475 Some browsers support right-clicking into the frame you want to refresh, just
2476 do this in the right frame.
2478 5.8 With Mozilla 0.9.7 I have problems sending a query modified in the query
2481 Looks like a Mozilla bug: 0.9.6 was OK. We will keep an eye on future Mozilla
2484 5.9 With Mozilla 0.9.? to 1.0 and Netscape 7.0-PR1 I can't type a whitespace in
2485 the SQL-Query edit area: the page scrolls down.
2487 This is a Mozilla bug (see bug #26882 at BugZilla).
2489 5.10 With Netscape 4.75 I get empty rows between each row of data in a CSV
2492 This is a known Netscape 4.75 bug: it adds some line feeds when exporting data
2493 in octet-stream mode. Since we can't detect the specific Netscape version, we
2494 cannot workaround this bug.
2496 5.11 Extended-ASCII characters like German umlauts are displayed wrong.
2498 Please ensure that you have set your browser's character set to the one of the
2499 language file you have selected on phpMyAdmin's start page. Alternatively, you
2500 can try the auto detection mode that is supported by the recent versions of the
2503 5.12 Mac OS X: Safari browser changes special characters to "?".
2505 This issue has been reported by a OS X user, who adds that Chimera, Netscape
2506 and Mozilla do not have this problem.
2508 5.13 With Internet Explorer 5.5 or 6, and HTTP authentication type, I cannot
2509 manage two servers: I log in to the first one, then the other one, but if I
2510 switch back to the first, I have to log in on each operation.
2512 This is a bug in Internet Explorer, other browsers do not behave this way.
2514 5.14 Using Opera6, I can manage to get to the authentication, but nothing
2515 happens after that, only a blank screen.
2517 Having $cfg['QueryFrameJS'] set o TRUE, this leads to a bug in Opera6, because
2518 it is not able to interpret frameset definitions written by JavaScript. Please
2519 upgrade your phpMyAdmin installtion or to Opera7 at least.
2521 5.15 I have display problems with Safari.
2523 Please upgrade to at least version 1.2.3.
2525 5.16 With Internet Explorer, I get "Access is denied" Javascript errors. Or I
2526 cannot make phpMyAdmin work under Windows.
2528 Please check the following points:
2530 * Maybe you have defined your PmaAbsoluteUri setting in config.inc.php to an
2531 IP address and you are starting phpMyAdmin with a URL containing a domain
2532 name, or the reverse situation.
2533 * Security settings in IE and/or Microsoft Security Center are too high, thus
2534 blocking scripts execution.
2535 * The Windows Firewall is blocking Apache and MySQL. You must allow HTTP
2536 ports (80 or 443) and MySQL port (usually 3306) in the "in" and "out"
2539 5.17 With Firefox, I cannot delete rows of data or drop a database.
2541 Many users have confirmed that the Tabbrowser Extensions plugin they installed
2542 in their Firefox is causing the problem.
2546 6.1 I can't insert new rows into a table / I can't create a table - MySQL
2547 brings up a SQL-error.
2549 Examine the SQL error with care. Often the problem is caused by specifying a
2551 Common errors include:
2553 * Using VARCHAR without a size argument
2554 * Using TEXT or BLOB with a size argument
2556 Also, look at the syntax chapter in the MySQL manual to confirm that your
2559 6.2 When I create a table, I click the Index checkbox for 2 fields and
2560 phpMyAdmin generates only one index with those 2 fields.
2562 In phpMyAdmin 2.2.0 and 2.2.1, this is the way to create a multi-fields index.
2563 If you want two indexes, create the first one when creating the table, save,
2564 then display the table properties and click the Index link to create the other
2567 6.3 How can I insert a null value into my table?
2569 Since version 2.2.3, you have a checkbox for each field that can be null.
2570 Before 2.2.3, you had to enter "null", without the quotes, as the field's
2571 value. Since version 2.5.5, you have to use the checkbox to get a real NULL
2572 value, so if you enter "NULL" this means you want a literal NULL in the field,
2573 and not a NULL value (this works in PHP4).
2575 6.4 How can I backup my database or table?
2577 Click on a database or table name in the left frame, the properties will be
2578 displayed. Then on the menu, click "Export", you can dump the structure, the
2579 data, or both. This will generate standard SQL statements that can be used to
2580 recreate your database/table.
2582 You will need to choose "Save as file", so that phpMyAdmin can transmit the
2583 resulting dump to your station. Depending on your PHP configuration, you will
2584 see options to compress the dump. See also the $cfg['ExecTimeLimit']
2585 configuration variable.
2587 For additional help on this subject, look for the word "dump" in this document.
2589 6.5 How can I restore (upload) my database or table using a dump? How can I run
2592 Click on a database name in the left frame, the properties will be displayed.
2593 Select "Import" from the list of tabs in the right?hand frame (or "SQL" if your
2594 phpMyAdmin version is previous to 2.7.0). In the "Location of the text file"
2595 section, type in the path to your dump filename, or use the Browse button. Then
2598 With version 2.7.0, the import engine has been re?written, if possible it is
2599 suggested that you upgrade to take advantage of the new features.
2601 For additional help on this subject, look for the word "upload" in this
2604 6.6 How can I use the relation table in Query-by-example?
2606 Here is an example with the tables persons, towns and countries, all located in
2607 the database mydb. If you don't have a pma_relation table, create it as
2608 explained in the configuration section. Then create the example tables:
2610 CREATE TABLE REL_countries (
2611 country_code char(1) NOT NULL default '',
2612 description varchar(10) NOT NULL default '',
2613 PRIMARY KEY (country_code)
2616 INSERT INTO REL_countries VALUES ('C', 'Canada');
2618 CREATE TABLE REL_persons (
2619 id tinyint(4) NOT NULL auto_increment,
2620 person_name varchar(32) NOT NULL default '',
2621 town_code varchar(5) default '0',
2622 country_code char(1) NOT NULL default '',
2626 INSERT INTO REL_persons VALUES (11, 'Marc', 'S', '');
2627 INSERT INTO REL_persons VALUES (15, 'Paul', 'S', 'C');
2629 CREATE TABLE REL_towns (
2630 town_code varchar(5) NOT NULL default '0',
2631 description varchar(30) NOT NULL default '',
2632 PRIMARY KEY (town_code)
2635 INSERT INTO REL_towns VALUES ('S', 'Sherbrooke');
2636 INSERT INTO REL_towns VALUES ('M', 'Montr?al');
2638 To setup appropriate links and display information:
2640 * on table "REL_persons" click Structure, then Relation view
2641 * in Links, for "town_code" choose "REL_towns->code"
2642 * in Links, for "country_code" choose "REL_countries->country_code"
2643 * on table "REL_towns" click Structure, then Relation view
2644 * in "Choose field to display", choose "description"
2645 * repeat the two previous steps for table "REL_countries"
2647 Then test like this:
2649 * Click on your db name in the left frame
2651 * Use tables: persons, towns, countries
2652 * Click "Update query"
2653 * In the fields row, choose persons.person_name and click the "Show" tickbox
2654 * Do the same for towns.description and countries.descriptions in the other 2
2656 * Click "Update query" and you will see in the query box that the correct
2657 joins have been generated
2658 * Click "Submit query"
2660 6.7 How can I use the "display field" feature?
2662 Starting from the previous example, create the pma_table_info as explained in
2663 the configuration section, then browse your persons table, and move the mouse
2664 over a town code or country code.
2666 See also FAQ 6.21 for an additional feature that "display field" enables:
2667 drop-down list of possible values.
2669 6.8 How can I produce a PDF schema of my database?
2671 First the configuration variables "relation", "table_coords" and "pdf_pages"
2672 have to be filled in.
2674 Then you need to think about your schema layout. Which tables will go on which
2677 * Select your database in the left frame.
2678 * Choose "Operations" in the navigation bar at the top.
2679 * Choose "Edit PDF Pages" near the bottom of the page.
2680 * Enter a name for the first PDF page and click Go. If you like, you can use
2681 the "automatic layout," which will put all your linked tables onto the new
2683 * Select the name of the new page (making sure the Edit radio button is
2684 selected) and click Go.
2685 * Select a table from the list, enter its coordinates and click Save.
2686 Coordinates are relative; your diagram will be automatically scaled to fit
2687 the page. When initially placing tables on the page, just pick any
2688 coordinates -- say, 50x50. After clicking Save, you can then use the
2689 graphical editor to position the element correctly.
2690 * When you'd like to look at your PDF, first be sure to click the Save button
2691 beneath the list of tables and coordinates, to save any changes you made
2692 there. Then scroll all the way down, select the PDF options you want, and
2694 * Internet Explorer for Windows may suggest an incorrect filename when you
2695 try to save a generated PDF. When saving a generated PDF, be sure that the
2696 filename ends in ".pdf", for example "schema.pdf". Browsers on other
2697 operating systems, and other browsers on Windows, do not have this problem.
2699 6.9 phpMyAdmin is changing the type of one of my columns!
2701 No, it's MySQL that is doing silent column type changing.
2703 6.10 When creating a privilege, what happens with underscores in the database
2706 If you do not put a backslash before the underscore, this is a wildcard grant,
2707 and the underscore means "any character". So, if the database name is
2708 "john_db", the user would get rights to john1db, john2db ...
2710 If you put a backslash before the underscore, it means that the database name
2711 will have a real underscore.
2713 6.11 What is the curious symbol ? in the statistics pages?
2717 6.12 I want to understand some Export options.
2721 * "Add DROP TABLE" will add a line telling MySQL to drop the table, if it
2722 already exists during the import. It does NOT drop the table after your
2723 export, it only affects the import file.
2724 * "If Not Exists" will only create the table if it doesn't exist. Otherwise,
2725 you may get an error if the table name exists but has a different
2727 * "Add AUTO_INCREMENT value" ensures that AUTO_INCREMENT value (if any) will
2728 be included in backup.
2729 * "Enclose table and field names with backquotes" ensures that field and
2730 table names formed with special characters are protected.
2731 * "Add into comments" includes column comments, relations, and MIME types set
2732 in the pmadb in the dump as SQL comments (/* xxx */).
2736 * "Complete inserts" adds the column names on every INSERT command, for
2737 better documentation (but resulting file is bigger).
2738 * "Extended inserts" provides a shorter dump file by using only once the
2739 INSERT verb and the table name.
2740 * "Delayed inserts" are best explained in the MySQL manual.
2741 * "Ignore inserts" treats errors as a warning instead. Again, more info is
2742 provided in the MySQL manual, but basically with this selected, invalid
2743 values are adjusted and inserted rather than causing the entire statement
2746 6.13 I would like to create a database with a dot in its name.
2748 This is a bad idea, because in MySQL the syntax "database.table" is the normal
2749 way to reference a database and table name. Worse, MySQL will usually let you
2750 create a database with a dot, but then you cannot work with it, nor delete it.
2752 6.14 How do I set up the SQL Validator?
2754 To use it, you need a very recent version of PHP, 4.3.0 recommended, with XML,
2755 PCRE and PEAR support. On your system command line, run "pear install
2756 Net_Socket Net_URL HTTP_Request Mail_Mime Net_DIME SOAP" to get the necessary
2757 PEAR modules for usage.
2758 On a more recent pear version, I had problems with the state of Net_DIME being
2759 beta, so this single command "pear -d preferred_state=beta install -a SOAP"
2760 installed all the needed modules.
2761 If you use the Validator, you should be aware that any SQL statement you submit
2762 will be stored anonymously (database/table/column names, strings, numbers
2763 replaced with generic values). The Mimer SQL Validator itself, is ? 2001
2764 Upright Database Technology. We utilize it as free SOAP service.
2766 6.15 I want to add a BLOB field and put an index on it, but MySQL says "BLOB
2767 column '...' used in key specification without a key length".
2769 The right way to do this, is to create the field without any indexes, then
2770 display the table structure and use the "Create an index" dialog. On this page,
2771 you will be able to choose your BLOB field, and set a size to the index, which
2772 is the condition to create an index on a BLOB field.
2774 6.16 How can I simply move in page with plenty editing fields?
2776 You can use Ctrl+arrows (Option+Arrows in Safari) for moving on most pages with
2777 many editing fields (table structure changes, row editing, etc.) (must be
2778 enabled in configuration - see. $cfg['CtrlArrowsMoving']). You can also have a
2779 look at the directive $cfg['DefaultPropDisplay'] ('vertical') and see if this
2780 eases up editing for you.
2782 6.17 Transformations: I can't enter my own mimetype! WTF is this feature then
2785 Slow down :). Defining mimetypes is of no use, if you can't put transformations
2786 on them. Otherwise you could just put a comment on the field. Because entering
2787 your own mimetype will cause serious syntax checking issues and validation,
2788 this introduces a high-risk false-user-input situation. Instead you have to
2789 initialize mimetypes using functions or empty mimetype definitions.
2790 Plus, you have a whole overview of available mimetypes. Who knows all those
2791 mimetypes by heart so he/she can enter it at will?
2793 6.18 Bookmarks: Where can I store bookmarks? Why can't I see any bookmarks
2794 below the query box? What is this variable for?
2796 Any query you have executed can be stored as a bookmark on the page where the
2797 results are displayed. You will find a button labeled 'Bookmark this query'
2798 just at the end of the page.
2799 As soon as you have stored a bookmark, it is related to the database you run
2800 the query on. You can now access a bookmark dropdown on each page, the query
2801 box appears on for that database.
2803 Since phpMyAdmin 2.5.0 you are also able to store variables for the bookmarks.
2804 Just use the string /*[VARIABLE]*/ anywhere in your query. Everything which is
2805 put into the value input box on the query box page will replace the string "/*
2806 [VARIABLE]*/" in your stored query. Just be aware of that you HAVE to create a
2807 valid query, otherwise your query won't be even able to be stored in the
2809 Also remember, that everything else inside the /*[VARIABLE]*/ string for your
2810 query will remain the way it is, but will be stripped of the /**/ chars. So you
2813 /*, [VARIABLE] AS myname */
2815 which will be expanded to
2817 , VARIABLE as myname
2819 in your query, where VARIABLE is the string you entered in the input box. If an
2820 empty string is provided, no replacements are made.
2822 A more complex example. Say you have stored this query:
2824 SELECT Name, Address FROM addresses WHERE 1 /* AND Name LIKE '%[VARIABLE]%' */
2826 Say, you now enter "phpMyAdmin" as the variable for the stored query, the full
2829 SELECT Name, Address FROM addresses WHERE 1 AND Name LIKE '%phpMyAdmin%'
2831 You can use multiple occurrences of /*[VARIABLE]*/ in a single query.
2832 NOTE THE ABSENCE OF SPACES inside the "/**/" construct. Any spaces inserted
2833 there will be later also inserted as spaces in your query and may lead to
2834 unexpected results especially when using the variable expansion inside of a
2835 "LIKE ''" expression.
2836 Your initial query which is going to be stored as a bookmark has to yield at
2837 least one result row so you can store the bookmark. You may have that to work
2838 around using well positioned "/**/" comments.
2840 6.19 How can I create simple L^AT[E]X document to include exported table?
2842 You can simply include table in your L^AT[E]X documents, minimal sample
2843 document should look like following one (assuming you have table exported in
2846 \documentclass{article} % or any class you want
2847 \usepackage{longtable} % for displaying table
2848 \begin{document} % start of document
2849 \include{table} % including exported table
2850 \end{document} % end of document
2852 6.20 In MySQL 4, I see a lot of databases which are not mine, and cannot access
2855 Upgrading to MySQL 4 usually gives users those global privileges: CREATE
2856 TEMPORARY TABLES, SHOW DATABASES, LOCK TABLES. Those privileges also enable
2857 users to see all the database names. See this bug report.
2859 So if your users do not need those privileges, you can remove them and their
2860 databases list will shorten.
2862 6.21 In edit/insert mode, how can I see a list of possible values for a field,
2863 based on some foreign table?
2865 You have to setup appropriate links between the tables, and also setup the
2866 "display field" in the foreign table. See FAQ 6.6 for an example. Then, if
2867 there are 200 values or less in the foreign table, a drop-down list of values
2868 will be available. You will see two lists of values, the first list containing
2869 the key and the display field, the second list containing the display field and
2870 the key. The reason for this is to be able to type the first letter of either
2871 the key or the display field.
2873 For 200 values or more, a distinct window will appear, to browse foreign key
2874 values and choose one.
2876 6.22 Bookmarks: Can I execute a default bookmark automatically when entering
2877 Browse mode for a table?
2879 Yes. If a bookmark has the same label as a table name, it will be executed.
2881 6.23 Export: I heard phpMyAdmin can export Microsoft Excel files, how can I
2884 Current version does support direct export to Microsoft Excel and Word versions
2885 2000 and newer. If you need export older versions, you can use CSV suitable for
2886 Microsoft Excel, which works out of the box or you can try native experimental
2887 MS Excel exporter. This export has several problems, most important are
2888 limitation of cell content to 255 chars and no support for charsets, so think
2889 carefully whether you want to enable this.. For enabling this you need to set
2890 $cfg['TempDir'] to place where web server user can write (for example './tmp')
2891 and install PEAR module Spreadsheet_Excel_Writer into php include path. The
2892 installation can be done by following command:
2894 pear -d preferred_state=beta install -a Spreadsheet_Excel_Writer
2896 First part of switches set we want to install beta version of that module (no
2897 stable version available yet) and then we tell pear we want to satisfy
2900 If you are running in PHP safe mode, you will have to set in php.ini the
2901 safe_mode_include_dir to the directory where your PEAR modules are located, for
2904 safe_mode_include_dir = /usr/local/lib/php
2906 To create the temporary directory on a UNIX-based system, you can do:
2912 6.24 Now that phpMyAdmin supports native MySQL 4.1.x column comments, what
2913 happens to my column comments stored in pmadb?
2915 Automatic migration of a table's pmadb-style column comments to the native ones
2916 is done whenever you enter Structure page for this table.
2920 7.1 I have found a bug. How do I inform developers?
2922 Our Bug Tracker is located at http://sf.net/projects/phpmyadmin/ under the Bugs
2925 But please first discuss your bug with other users:
2926 http://sf.net/projects/phpmyadmin/ (and choose Forums)
2928 7.2 I want to translate the messages to a new language or upgrade an existing
2929 language, where do I start?
2931 Always use the current SVN version of your language file. For a new language,
2932 start from english-iso-8859-1.inc.php. If you don't know how to get the SVN
2933 version, please ask one of the developers.
2934 Please note that we try not to use HTML entities like é in the
2935 translations, since we define the right character set in the file. With HTML
2936 entities, the text on JavaScript messages would not display correctly. However
2937 there are some entities that need to be there, for quotes ,non-breakable
2938 spaces, ampersands, less than, greater than.
2939 You can then put your translations, as a zip file to avoid losing special
2940 characters, on the sourceforge.net translation tracker.
2941 It would be a good idea to subscribe to the phpmyadmin-translators mailing
2942 list, because this is where we ask for translations of new messages.
2944 7.3 I would like to help out with the development of phpMyAdmin. How should I
2947 The following method is preferred for new developers:
2949 1. fetch the current SVN tree over anonymous SVN:
2950 svn co https://phpmyadmin.svn.sourceforge.net/svnroot/phpmyadmin/trunk/
2953 3. generate patch with your changes: svn diff
2954 4. put the patch inside the patch tracker of the phpMyAdmin project.
2956 Write access to the SVN tree is granted only to experienced developers who have
2957 already contributed something useful to phpMyAdmin.
2958 Also, have a look at the Developers section.
2962 8.1 Where can I get information about the security alerts issued for
2965 Please refer to http://www.phpmyadmin.net/home_page/security.php
2967 Developers Information
2969 phpMyAdmin is Open Source, so you're invited to contribute to it. Many great
2970 features have been written by other people and you too can help to make
2971 phpMyAdmin a useful tool.
2973 If you're planning to contribute source, please read the following information:
2975 * All files include libraries/header.inc.php (layout),. libraries/
2976 common.lib.php (common functions) and config.inc.php.
2977 Only configuration data should go in config.inc.php. Please keep it free
2979 Commonly used functions should be added to libraries/common.lib.php and
2980 more specific ones may be added within a library stored into the libraries
2982 * Obviously, you're free to use whatever coding style you want. But please
2983 try to keep your code as simple as possible: beginners are using phpMyAdmin
2984 as an example application.
2985 As far as possible, we want the scripts to be XHTML1.0 and CSS2 compliant
2986 on one hand, they fit the PEAR coding standards on the other hand. Please
2987 pay attention to this.
2988 * Please try to keep up the file-naming conventions. Table-related stuff goes
2989 to tbl_*.php, db-related code to db_*.php, server-related tools to
2990 server_*.php and so on.
2991 * Please don't use verbose strings in your code, instead add the string (at
2992 least) to english-iso-8859-1.inc.php and print() it out.
2993 * If you want to be really helpful, write an entry for the ChangeLog.
2994 * The DBG extension (PHP Debugger DBG) is now supported by phpMyAdmin for
2995 developers to better debug and profile their code.
2996 Please see the $cfg['DBG']* configuration options for more information.
2997 This is in memoriam of the Space Shuttle Columbia (STS-107) which was lost
2998 during its re-entry into Earth's atmosphere and in memory of the brave men
2999 and women who gave their lives for the people of Earth.
3003 phpMyAdmin - Credits
3004 ====================
3006 CREDITS, in chronological order
3007 -------------------------------
3009 - Tobias Ratschiller <tobias_at_ratschiller.com>
3010 * creator of the phpmyadmin project
3011 * maintainer from 1998 to summer 2000
3013 - Marc Delisle <Marc.Delisle_at_cegepsherbrooke.qc.ca>
3014 * multi-language version
3015 * various fixes and improvements
3016 * SQL analyser (most of it)
3017 * current project maintainer
3019 - Olivier M?ller <om_at_omnis.ch>
3020 * started SourceForge phpMyAdmin project in March 2001
3021 * sync'ed different existing CVS trees with new features and bugfixes
3022 * multi-language improvements, dynamic language selection
3023 * current project maintainer
3024 * many bugfixes and improvements
3026 - Lo?c Chapeaux <lolo_at_phpheaven.net>
3027 * rewrote and optimized javascript, DHTML and DOM stuff
3028 * rewrote the scripts so they fit the PEAR coding standards and
3029 generate XHTML1.0 and CSS2 compliant codes
3030 * improved the language detection system
3031 * many bugfixes and improvements
3033 - Robin Johnson <robbat2_at_users.sourceforge.net>
3034 * database maintenance controls
3036 * Host authentication IP Allow/Deny
3037 * DB-based configuration (Not completed)
3038 * SQL parser and pretty-printer
3040 * many bugfixes and improvements
3042 - Armel Fauveau <armel.fauveau_at_globalis-ms.com>
3044 * multiple dump feature
3048 - Geert Lund <glund_at_silversoft.dk>
3050 * moderator of the phpMyAdmin former users forum at phpwizard.net
3052 - Korakot Chaovavanich <korakot_at_iname.com>
3053 * "insert as new row" feature
3055 - Pete Kelly <webmaster_at_trafficg.com>
3056 * rewrote and fix dump code
3059 - Steve Alberty <alberty_at_neptunlabs.de>
3060 * rewrote dump code for PHP4
3061 * mySQL table statistics
3064 - Benjamin Gandon <gandon_at_isia.cma.fr>
3065 * main author of the version 2.1.0.1
3068 - Alexander M. Turek <me_at_derrabus.de>
3069 * MySQL 4.0 / 4.1 / 5.0 compatibility
3070 * abstract database interface (PMA_DBI) with MySQLi support
3071 * privileges administration
3073 * various features and fixes
3074 * German language file updates
3076 - Mike Beck <mike.beck_at_web.de>
3077 * automatic joins in QBE
3078 * links column in printview
3081 - Michal ?iha? <michal_at_cihar.com>
3082 * enhanced index creation/display feature
3083 * feature to use a different charset for HTML than for MySQL
3084 * improvements of export feature
3085 * various features and fixes
3086 * Czech language file updates
3088 - Christophe Gesch? from the "MySQL Form Generator for PHPMyAdmin"
3089 (http://sf.net/projects/phpmysqlformgen/)
3090 * suggested the patch for multiple table printviews
3092 - Garvin Hicking <me_at_supergarv.de>
3093 * built the patch for vertical display of table rows
3094 * built the Javascript based Query window + SQL history
3095 * Improvement of column/db comments
3096 * (MIME)-Transformations for columns
3097 * Use custom alias names for Databases in left frame
3098 * hierarchical/nested table display
3099 * PDF-scratchboard for WYSIWYG-distribution of PDF relations
3101 * vertical display of column properties page
3102 * some bugfixes, features, support, German language additions
3104 - Yukihiro Kawada <kawada_at_den.fujifilm.co.jp>
3105 * japanese kanji encoding conversion feature
3107 - Piotr Roszatycki <d3xter_at_users.sourceforge.net> and Dan Wilson
3108 * the Cookie authentication mode
3110 - Axel Sander <n8falke_at_users.sourceforge.net>
3111 * table relation-links feature
3113 - Maxime Delorme <delorme.maxime_at_free.fr>
3114 * PDF schema output, thanks also to Olivier Plathey for the
3115 "FPDF" library (see http://www.fpdf.org/) and Steven Wittens
3116 for the "UFPDF" library (see http://www.acko.net/node/56).
3118 - Olof Edlund <olof.edlund_at_upright.se>
3119 * SQL validator server
3121 - Ivan R. Lanin <ivanlanin_at_users.sourceforge.net>
3122 * phpMyAdmin logo (until June 2004)
3124 - Mike Cochrane <mike_at_graftonhall.co.nz>
3125 * blowfish library from the Horde project
3127 - Marcel Tschopp <ne0x_at_users.sourceforge.net>
3129 * many bugfixes and improvements
3131 - Michael Keck <mkkeck_at_users.sourceforge.net>
3132 * redesign for 2.6.0
3133 * phpMyAdmin sailboat logo (June 2004)
3135 - Mathias Landh?u?er
3136 * Representation at conferences
3138 - Sebastian Mendel <cybot_tm_at_users.sourceforge.net>
3139 * interface improvements
3143 * new relations Designer
3145 And also to the following people who have contributed minor changes,
3146 enhancements, bugfixes or support for a new language since version 2.1.0:
3148 Bora Alioglu, Ricardo ?, Sven-Erik Andersen, Alessandro Astarita,
3149 P?ter Bakondy, Borges Botelho, Olivier Bussier, Neil Darlow,
3150 Mats Engstrom, Ian Davidson, Laurent Dhima, Kristof Hamann, Thomas Kl?ger,
3151 Lubos Klokner, Martin Marconcini, Girish Nair, David Nordenberg, Andreas Pauley,
3152 Bernard M. Piller, Laurent Haas, "Sakamoto", Yuval Sarna,
3153 www.securereality.com.au, Alexis Soulard, Alvar Soome, Siu Sun, Peter Svec,
3154 Michael Tacelosky, Rachim Tamsjadi, Kositer Uros,
3155 Lu?s V., Martijn W. van der Lee,
3156 Algis Vainauskas, Daniel Villanueva, Vinay, Ignacio Vazquez-Abrams, Chee Wai,
3157 Jakub Wilk, Thomas Michael Winningham, Vilius Zigmantas, "Manuzhai".
3160 Original Credits of Version 2.1.0
3161 ---------------------------------
3163 This work is based on Peter Kuppelwieser's MySQL-Webadmin. It was his idea
3164 to create a web-based interface to MySQL using PHP3. Although I have not
3165 used any of his source-code, there are some concepts I've borrowed from
3166 him. phpMyAdmin was created because Peter told me he wasn't going to
3167 further develop his (great) tool.
3169 - Amalesh Kempf <ak-lsml_at_living-source.com> who contributed the
3170 code for the check when dropping a table or database. He also suggested
3171 that you should be able to specify the primary key on tbl_create.php3. To
3172 version 1.1.1 he contributed the ldi_*.php3-set (Import text-files) as
3173 well as a bug-report. Plus many smaller improvements.
3174 - Jan Legenhausen <jan_at_nrw.net>: He made many of the changes that
3175 were introduced in 1.3.0 (including quite significant ones like the
3176 authentication). For 1.4.1 he enhanced the table-dump feature. Plus
3178 - Marc Delisle <DelislMa_at_CollegeSherbrooke.qc.ca> made phpMyAdmin
3179 language-independent by outsourcing the strings to a separate file. He
3180 also contributed the French translation.
3181 - Alexandr Bravo <abravo_at_hq.admiral.ru> who contributed
3182 tbl_select.php3, a feature to display only some fields from a table.
3183 - Chris Jackson <chrisj_at_ctel.net> added support for MySQL
3184 functions in tbl_change.php3. He also added the
3185 "Query by Example" feature in 2.0.
3186 - Dave Walton <walton_at_nordicdms.com> added support for multiple
3187 servers and is a regular contributor for bug-fixes.
3188 - Gabriel Ash <ga244_at_is8.nyu.edu> contributed the random access
3190 The following people have contributed minor changes, enhancements, bugfixes
3191 or support for a new language:
3192 Jim Kraai, Jordi Bruguera, Miquel Obrador, Geert Lund, Thomas Kleemann,
3193 Alexander Leidinger, Kiko Albiol, Daniel C. Chao, Pavel Piankov,
3194 Sascha Kettler, Joe Pruett, Renato Lins, Mark Kronsbein, Jannis Hermanns,
3197 And thanks to everyone else who sent me email with suggestions, bug-reports
3198 and or just some feedback.
3202 From Wikipedia, the free encyclopedia
3204 * .htaccess - the default name of Apache's directory-level configuration
3206 * Blowfish - a keyed, symmetric block cipher, designed in 1993 by Bruce
3208 * Browser (Web Browser) - a software application that enables a user to
3209 display and interact with text, images, and other information typically
3210 located on a web page at a website on the World Wide Web.
3211 * bzip2 - a free software/open source data compression algorithm and program
3212 developed by Julian Seward.
3213 * CGI (Common Gateway Interface) - an important World Wide Web technology
3214 that enables a client web browser to request data from a program executed
3216 * Changelog - a log or record of changes made to a project.
3217 * Client - a computer system that accesses a (remote) service on another
3218 computer by some kind of network.
3219 * column - a set of data values of a particular simple type, one for each row
3221 * Cookie - a packet of information sent by a server to a World Wide Web
3222 browser and then sent back by the browser each time it accesses that
3224 * CSV - Comma-seperated values
3225 * DB - look at Database.
3226 * database - an organized collection of data.
3227 * Engine - look at Storage Engines.
3228 * extension - a PHP module that extends PHP with additional functionality.
3229 * FAQ (Frequently Asked Questions) - a list of commonly asked question and
3231 * Field - one part of divided data/columns.
3232 * foreign key - a field or group of fields in a database record that point to
3233 a key field or group of fields forming a key of another database record in
3234 some (usually different) table.
3235 * FPDF (FreePDF) - the free PDF library
3236 * GD Graphics Library - a library by Thomas Boutell and others for
3237 dynamically manipulating images.
3238 * GD2 - look at GD Graphics Library.
3239 * gzip - gzip is short for GNU zip, a GNU free software file compression
3241 * host - any machine connected to a computer network, a node that has a
3243 * hostname - the unique name by which a network attached device is known on a
3245 * HTTP (HyperText Transfer Protocol) - the primary method used to transfer or
3246 convey information on the World Wide Web.
3247 * https - a HTTP-connection with additional security measures.
3248 * IIS (Internet Information Services) - a set of Internet-based services for
3249 servers using Microsoft Windows.
3250 * Index - a feature that allows quick access to the rows in a table.
3251 * IP (Internet Protocol) - a data-oriented protocol used by source and
3252 destination hosts for communicating data across a packet-switched
3254 * IP Address - a unique number that devices use in order to identify and
3255 communicate with each other on a network utilizing the Internet Protocol
3257 * ISAPI (Internet Server Application Programming Interface) - the API of
3258 Internet Information Services (IIS).
3259 * ISP (Internet service provider) - a business or organization that offers
3260 users access to the Internet and related services.
3261 * JPEG - a most commonly used standard method of lossy compression for
3262 photographic images.
3263 * JPG - look at JPEG.
3264 * Key - look at index.
3265 * L^AT[E]X - a document preparation system for the T[E]X typesetting program.
3266 * Mac (Apple Macintosh) - line of personal computers is designed, developed,
3267 manufactured, and marketed by Apple Computer.
3268 * Mac OS X - the operating system which is included with all currently
3269 shipping Apple Macintosh computers in the consumer and professional
3271 * MCrypt - a cryptographic library.
3272 * mcrypt - the MCrypt PHP extension.
3273 * MIME (Multipurpose Internet Mail Extensions) - an Internet Standard for the
3275 * module - some sort of extension for the Apache Webserver.
3276 * MySQL - a multithreaded, multi-user, SQL (Structured Query Language)
3277 Database Management System (DBMS).
3278 * mysqli - the improved MySQL client PHP extension.
3279 * mysql - the MySQL client PHP extension.
3280 * OpenDocument - open standard for office documents.
3281 * OS X - look at Mac OS X.
3282 * PDF (Portable Document Format) - a file format developed by Adobe Systems
3283 for representing two dimensional documents in a device independent and
3284 resolution independent format.
3285 * PEAR - the PHP Extension and Application Repository.
3286 * PCRE (Perl Compatible Regular Expressions) - the perl-compatible regular
3287 expression functions for PHP
3288 * PHP - short for "PHP: Hypertext Preprocessor", is an open-source,
3289 reflective programming language used mainly for developing server-side
3290 applications and dynamic web content, and more recently, a broader range of
3291 software applications.
3292 * port - a connection through which data is sent and received.
3293 * RFC - Request for Comments (RFC) documents are a series of memoranda
3294 encompassing new research, innovations, and methodologies applicable to
3295 Internet technologies.
3296 * RFC 1952 - GZIP file format specification version 4.3
3297 * Row (record, tulpel) - represents a single, implicitly structured data item
3299 * Server - a computer system that provides services to other computing
3300 systems over a network.
3301 * Storage Engines - handlers for different table types
3302 * socket - a form of inter-process communication.
3303 * SSL (Secure Sockets Layer) - a cryptographic protocol which provides secure
3304 communication on the Internet.
3305 * SQL - Structured Query Language
3306 * table - a set of data elements (cells) that is organized, defined and
3307 stored as horizontal rows and vertical columns where each item can be
3308 uniquely identified by a label or key or by it?s position in relation to
3311 * tar - a type of archive file format: the Tape ARchive format.
3312 * TCP (Transmission Control Protocol) - one of the core protocols of the
3313 Internet protocol suite.
3314 * UFPDF - Unicode/UTF-8 extension for FPDF
3315 * URL (Uniform Resource Locator) - a sequence of characters, conforming to a
3316 standardized format, that is used for referring to resources, such as
3317 documents and images on the Internet, by their location.
3318 * Webserver - A computer (program) that is responsible for accepting HTTP
3319 requests from clients and serving them Web pages.
3320 * XML (Extensible Markup Language) - a W3C-recommended general-purpose markup
3321 language for creating special-purpose markup languages, capable of
3322 describing many different kinds of data.
3323 * ZIP - a popular data compression and archival format.
3324 * zlib - an open-source, cross-platform data compression library by Jean-loup
3325 Gailly and Mark Adler.
3327 Valid XHTML 1.1 Valid CSS!