Merge branch 'master' of git://github.com/openemr/openemr
[openemr.git] / phpmyadmin / Documentation.txt
blob8d2825512475fd4c1dba1fd446824ec2a33b10e2
1   * Top
2   * Requirements
3   * Introduction
4   * Installation
5   * Setup script
6   * Configuration
7   * Transformations
8   * FAQ
9   * Developers
10   * Credits
11   * Translators
12   * Glossary
14 phpMyAdmin 2.11.9.5 Documentation
16   * phpMyAdmin homepage
17   * SourceForge phpMyAdmin project page
18   * Official phpMyAdmin wiki
19   * Local documents:
20       + Version history: ChangeLog
21       + General notes: README
22       + License: LICENSE
23   * Documentation version: $Id: Documentation.html 12317 2009-03-24 21:04:18Z
24     lem9 $
26 Requirements
28   * PHP
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
37         slower.
38   * MySQL 3.23.32 or newer (details);
39   * Web browser with cookies enabled.
41 Introduction
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
53     configuration
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
72 A word about users:
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.
84 Installation
86  1. Quick Install
87  2. Setup script usage
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").
102 Quick Install
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
130         this:
132         <?php
133         $cfg['blowfish_secret'] = 'ba17c1ec07d65003';  // use here a value of your choice
135         $i=0;
136         $i++;
137         $cfg['Servers'][$i]['auth_type']     = 'cookie';
138         ?>
140         Or, if you prefer to not be prompted every time you log in:
142         <?php
144         $i=0;
145         $i++;
146         $cfg['Servers'][$i]['user']          = 'root';
147         $cfg['Servers'][$i]['password']      = 'cbb74bc'; // use here your password
148         ?>
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:
157         cd phpMyAdmin
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
180         measure:
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
194     FAQ 4.4.
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
214 FAQ 1.23).
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
225 name.
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
231 below).
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
255     in this area!
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
258     file.
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';
285     GRANT SELECT (
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:
300     GRANT SELECT (
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
318     database user_base:
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
323     management system.
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
330     MySQL user.
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'
334     authentication mode.
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']
345     directive.
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
365     configuration file.
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
375     Google).
377 Configuration
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
406     improve the code.
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
457     platforms.
459     To use the socket mode, your MySQL server must be on the same machine as
460     the Web server.
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
465     method at this time.
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
469     4.1.x.
470 $cfg['Servers'][$i]['compress'] boolean
471     Whether to use a compressed protocol for the MySQL server connection or not
472     (experimental).
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
488     information.
490     In phpMyAdmin versions before 2.2.5, those were called "stduser/stdpass".
491 $cfg['Servers'][$i]['auth_type'] string ['HTTP'|'http'|'cookie'|'config'|
492     'signon']
493     Whether config or cookie or HTTP or signon authentication should be used
494     for this server.
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
512     information.
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
518     empty.
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
542     databases.
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
547     alphabetic order.
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
591     this to
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);
597         (see FAQ 6.7)
598       + in edit/insert mode, display a drop-down list of possible foreign keys
599         (key value and "display field" are shown)
600         (see FAQ 6.21)
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
605         table_coords table).
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
616     cross-db relations.
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
634     output).
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]
671         ['column_info']
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
680     amount.
682     The query history is only available if JavaScript is enabled in your
683     browser.
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
705     to date.
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
729     proxies.
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
739     webservers):
741     'all' -> 0.0.0.0/0
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
769     logging in.
770     If you have only one server configured, $cfg['ServerDefault'] MUST be set
771     to that server.
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
787     transfers.
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
794     mysql_pconnect).
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
813     not.
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
828     authentication mode.
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.
847     Defaults to TRUE.
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
862     them in a tree.
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
872     the above separator.
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
880     real name of the DB.
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
886     real tablename.
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
893     this is main.php.
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]
915     ['verbose'].
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
931     passwords.
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
937     content.
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
944     browse mode or not.
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
962     from the interface.
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
969         limitations
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
985     creating a dump file
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
994     mainframe.
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
1015     "sql.php".
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
1020     their types.
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
1030     user-defined.
1031     See the select_lang.lib.php script to know the valid values for this
1032     setting.
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.
1036 $cfg['Lang'] string
1037     Force: always use this language (must be defined in the select_lang.lib.php
1038     script).
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
1060         recode)
1061       + iconv - use iconv or libiconv functions
1062       + recode - use recode_string function
1063     Default is auto.
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
1080     1.2.3.4:
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
1089     transformations.
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
1093         possibilities
1094       + yes - GD 2 functions can be used
1095       + no - GD 2 function cannot be used
1096     Default is auto.
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/
1102     layout.inc.php.
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/
1106     layout.inc.php.
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
1155     editing.
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
1170     lineup.
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
1207     tab.
1209     If you want different directory for each user, %u will be replaced with
1210     username.
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
1226     username.
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
1240     mean.
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
1244     mean.
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
1273     Mozilla 1.x.
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:
1341     @HTTP_HOST@
1342         HTTP host that runs phpMyAdmin
1343     @SERVER@
1344         MySQL server name
1345     @VERBOSE@
1346         Verbose MySQL server name as defined in server configuration
1347     @VSERVER@
1348         Verbose MySQL server name if set, otherwise normal
1349     @DATABASE@
1350         Currently opened database
1351     @TABLE@
1352         Currently opened table
1353     @PHPMYADMIN@
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
1394     colour strings.
1395     Class name key:
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
1413         attribute
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
1428         .
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.
1436 $cfg['DBG']
1437     DEVELOPERS ONLY!
1438 $cfg['DBG']['enable'] boolean
1439     DEVELOPERS ONLY!
1440     Enable the DBG extension for debugging phpMyAdmin. Required for profiling
1441     the code.
1442     For help in setting up your system to this, see the Developers section.
1443 $cfg['DBG']['profile']['enable'] boolean
1444     DEVELOPERS ONLY!
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
1450     licensing issues.
1451 $cfg['DBG']['profile']['threshold'] float (units in milliseconds)
1452     DEVELOPERS ONLY!
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
1457     to edit this.
1458 $cfg['ColumnTypes'] array
1459     All possible types of a MySQL column. In most cases you don't need to edit
1460     this.
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
1465     this.
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
1486     null.
1488 Transformations
1490  1. Introduction
1491  2. Usage
1492  3. File structure
1494 1. Introduction
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.
1517 2. Usage
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/
1536     jpeg').
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'".
1556 3. File structure
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
1562 transformations.
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]()'.
1590     Example:
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]__
1603     [transform]()'.
1605     Example:
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.
1618     Example:
1620     text_plain.inc.php
1621     (No function)
1622  4. A mimetype (w/o subtype) without specific transform function
1624     [mimetype].inc.php
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.
1631     Example:
1633     text.inc.php
1634     (No function)
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__
1640     [transform]()'.
1642     Example:
1644     global__formatted
1645     PMA_transform_global__formatted()
1647 So generally use '_' to split up mimetype and subtype, and '__' to provide a
1648 transform function.
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
1660 language file.
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
1669     want to transform.
1670  2. $options - Contains any user-passed options to a transform function as an
1671     array.
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
1682  1. Server
1683  2. Configuration
1684  3. Known limitations
1685  4. ISPs, multi-user installations
1686  5. Browsers or client OS
1687  6. Using phpMyAdmin
1688  7. phpMyAdmin project
1689  8. Security
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.
1694 Server
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
1703 file.
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
1713 support groups.
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
1725 ...".
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
1748 --with-bz2).
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
1754 being in effect.
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/
1763     php
1764   * give proper permission: chmod 600 /tmp/php
1765   * put upload_tmp_dir = /tmp/php in php.ini
1766   * restart Apache
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
1770 line.
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
1779 away.
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
1786 httpd.conf:
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
1793 box.
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
1809 the uploaded query.
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
1815 increase it.
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
1872 FAQ 1.17.
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
1884 corresponding file.
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
1893 use font faces.
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
1897 Configuration".
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
1908 cookie auth.
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
1915 to "on".
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,
1942 like this:
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
1958 plenty of tables).
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
1974 duplicated.
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
1980 used:
1982 SetOutputFilter PHP
1983 SetInputFilter PHP
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
1992 and restart Apache:
1994 #SetOutputFilter PHP
1995 #SetInputFilter 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?
2004 Yes.
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
2011 under IIS 5.1.
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
2019     to Default button.
2021 1.33 Is there a problem with the mysqli extension when running PHP 5.0.4 on
2022 64-bit systems?
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):
2041 RewriteEngine On
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
2051 rewrite rule:
2053 RewriteEngine On
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
2067 this case.
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.
2077 Configuration
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
2087 cleared his errors.
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
2097 I do?
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
2106 change it to
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
2121     the config.inc.php.
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
2147 for my localhost.
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
2151 expected.
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
2155 forwarding.
2156 If you enter "127.0.0.1" as hostname, everything is right and MySQL uses the
2157 TCP connection.
2159 2.7 Using and creating themes
2161 Themes are configured with $cfg['ThemePath'], $cfg['ThemeManager'] and $cfg
2162 ['ThemeDefault'].
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.
2173 To create a theme:
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/
2184     screen.png"
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.
2202     See also FAQ 4.7.
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.
2215 Known limitations
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
2233 a table.
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
2241 this:
2243 -- MySQL dump 8.22
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
2263 that feature
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
2271 the foreign table.
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
2301 #816858
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
2325 hyphen.
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
2332 of the columns.
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.
2356 Suggestions:
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
2361     which Apache runs.
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 /
2366 libraries.
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
2400 blocks.
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',
2410     );
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
2446 seem to work.
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
2453 stores the cookies.
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
2457 this area!
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
2466 field
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
2479 box.
2481 Looks like a Mozilla bug: 0.9.6 was OK. We will keep an eye on future Mozilla
2482 versions.
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
2490 exported file.
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
2501 most browsers.
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"
2537     directions.
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.
2544 Using phpMyAdmin
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
2550 wrong field-type.
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
2557 syntax is correct.
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
2565 index.
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
2590 a ".sql" file?
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
2596 click Go.
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
2602 document.
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)
2614 ) TYPE=MyISAM;
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 '',
2623     PRIMARY KEY (id)
2624 ) TYPE=MyISAM;
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)
2633 ) TYPE=MyISAM;
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
2650   * Choose "Query"
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
2655     columns
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
2675 pages?
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
2682     page.
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
2693     click Go.
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
2704 name?
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?
2715 It means "average".
2717 6.12 I want to understand some Export options.
2719 Structure:
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
2726     structure.
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 */).
2734 Data:
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
2744     to fail.
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
2783 useful for?
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
2808 database.
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
2811 can use:
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
2827 query will be:
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
2844 file table.tex):
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
2853 them.
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
2882 enable that?
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
2898 dependencies.
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
2902 example:
2904 safe_mode_include_dir = /usr/local/lib/php
2906 To create the temporary directory on a UNIX-based system, you can do:
2908 cd phpMyAdmin
2909 mkdir tmp
2910 chmod o+rwx tmp
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.
2918 phpMyAdmin project
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
2923 section.
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 &eacute; 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
2945 proceed?
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/
2951     phpMyAdmin
2952  2. add your stuff
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.
2960 Security
2962 8.1 Where can I get information about the security alerts issued for
2963 phpMyAdmin?
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
2978     from other code.
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
2981     sub-directory.
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.
3001 Credits
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
3035     * table type code
3036     * Host authentication IP Allow/Deny
3037     * DB-based configuration (Not completed)
3038     * SQL parser and pretty-printer
3039     * SQL validator
3040     * many bugfixes and improvements
3042 - Armel Fauveau <armel.fauveau_at_globalis-ms.com>
3043     * bookmarks feature
3044     * multiple dump feature
3045     * gzip dump feature
3046     * zip dump feature
3048 - Geert Lund <glund_at_silversoft.dk>
3049     * various fixes
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
3057     * bugfixes
3059 - Steve Alberty <alberty_at_neptunlabs.de>
3060     * rewrote dump code for PHP4
3061     * mySQL table statistics
3062     * bugfixes
3064 - Benjamin Gandon <gandon_at_isia.cma.fr>
3065     * main author of the version 2.1.0.1
3066     * bugfixes
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
3072     * XML exports
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
3079     * Relation view
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
3100     * new icon sets
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>
3128     * mysqli support
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
3140     * various bugfixes
3142 - Ivan A Kirillov
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.
3168     Thanks go to
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
3177       bug-fixes and help.
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
3189       features for 2.0.6.
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,
3195     G. Wieggers.
3197     And thanks to everyone else who sent me email with suggestions, bug-reports
3198     and or just some feedback.
3200 Glossary
3202 From Wikipedia, the free encyclopedia
3204   * .htaccess - the default name of Apache's directory-level configuration
3205     file.
3206   * Blowfish - a keyed, symmetric block cipher, designed in 1993 by Bruce
3207     Schneier.
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
3215     on the Web server.
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
3220     of the table.
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
3223     server.
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
3230     there answers.
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
3240     program.
3241   * host - any machine connected to a computer network, a node that has a
3242     hostname.
3243   * hostname - the unique name by which a network attached device is known on a
3244     network.
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
3253     internetwork.
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
3256     standard.
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
3270     markets.
3271   * MCrypt - a cryptographic library.
3272   * mcrypt - the MCrypt PHP extension.
3273   * MIME (Multipurpose Internet Mail Extensions) - an Internet Standard for the
3274     format of e-mail.
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
3298     in a table.
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
3309     other items.
3310   * Table type
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!