In order to have these functions available, you must compile PHP with support for the mysqli extension.
The mysqli extension is designed to work with MySQL version 4.1.13 or newer, or 5.0.7 or newer. For previous versions, please see the MySQL extension documentation.
mysqli extension was introduced with PHP
version 5.0.0. The MySQL Native Driver was included in PHP
The common Unix distributions include binary versions of PHP that can be installed. Although these binary versions are typically built with support for MySQL extensions enabled, the extension libraries themselves may need to be installed using an additional package. Check the package manager than comes with your chosen distribution for availability.
Unless your Unix distribution comes with a binary package of
PHP with the
mysqli extension available,
you will need to build PHP from source code. Building PHP from
source allows you to specify the MySQL extensions you want to
use, as well as your choice of client library for each
The MySQL Native Driver is the recommended option, as it results in improved performance and gives access to features not available when using the MySQL Client Library. Refer to What is PHP's MySQL Native Driver? for a brief overview of the advantages of MySQL Native Driver.
/path/to/mysql_config represents the
location of the
mysql_config program that
comes with MySQL Server.
Table 17.39. mysqli compile time support matrix
|PHP Version||Default||Configure Options: mysqlnd||Configure Options: ||Changelog|
|5.0.x, 5.1.x, 5.2.x||libmysqlclient||Not Available|
|5.3.x||libmysqlclient||mysqlnd is now supported|
|5.4.x||mysqlnd||mysqlnd is now the default|
Note that it is possible to freely mix MySQL extensions and
client libraries. For example, it is possible to enable the
MySQL extension to use the MySQL Client Library
(libmysqlclient), while configuring the
mysqli extension to use the MySQL Native
Driver. However, all permutations of extension and client
library are possible.
The following example builds the MySQL extension to use the
MySQL Client Library, and the
PDO MYSQL extensions to use the MySQL Native Driver:
./configure --with-mysql=/usr/bin/mysql_config \ --with-mysqli=mysqlnd \ --with-pdo-mysql=mysqlnd [other options]
On Windows, PHP is most commonly installed using the binary installer.
Once PHP has been installed, some configuration is required
mysqli and specify the client
library you want it to use.
mysqli extension is not enabled by
default, so the
php_mysqli.dll DLL must
be enabled inside of
php.ini. In order
to do this you need to find the
file (typically located in
make sure you remove the comment (semi-colon) from the start
of the line
the section marked
Also, if you want to use the MySQL Client Library with
mysqli, you need to make sure PHP can
access the client library file. The MySQL Client Library is
included as a file named
in the Windows PHP distribution. This file needs to be
available in the Windows system's
environment variable, so that it can be successfully loaded.
See the FAQ titled
do I add my PHP directory to the PATH on
Windows" for information on how to do this.
libmysql.dll to the Windows
system directory (typically
c:\Windows\system) also works, as the
system directory is by default in the system's
PATH. However, this practice is strongly
As with enabling any PHP extension (such as
php_mysqli.dll), the PHP directive
should be set to the directory where the PHP extensions are
located. See also the
Windows Installation Instructions. An example
extension_dir value for PHP 5 is
If when starting the web server an error similar to the
"Unable to load dynamic
library './php_mysqli.dll'", this
libmysql.dll cannot be found by the
On Windows, for PHP versions 5.3 and newer, the
mysqli extension is enabled and uses the
MySQL Native Driver by default. This means you don't
need to worry about configuring access to
The behaviour of these functions is affected by settings in
Table 17.40. MySQLi Configuration Options
|mysqli.allow_local_infile||"1"||PHP_INI_SYSTEM||Available since PHP 5.2.4.|
|mysqli.allow_persistent||"1"||PHP_INI_SYSTEM||Available since PHP 5.3.0.|
|mysqli.max_persistent||"-1"||PHP_INI_SYSTEM||Available since PHP 5.3.0.|
|mysqli.max_links||"-1"||PHP_INI_SYSTEM||Available since PHP 5.0.0.|
|mysqli.default_port||"3306"||PHP_INI_ALL||Available since PHP 5.0.0.|
|mysqli.default_socket||NULL||PHP_INI_ALL||Available since PHP 5.0.0.|
|mysqli.default_host||NULL||PHP_INI_ALL||Available since PHP 5.0.0.|
|mysqli.default_user||NULL||PHP_INI_ALL||Available since PHP 5.0.0.|
|mysqli.default_pw||NULL||PHP_INI_ALL||Available since PHP 5.0.0.|
|mysqli.reconnect||"0"||PHP_INI_SYSTEM||Available since PHP 4.3.5.|
|mysqli.cache_size||"2000"||PHP_INI_SYSTEM||Available since PHP 5.3.0.|
For further details and definitions of the preceding PHP_INI_* constants, see the chapter on configuration changes.
Here's a short explanation of the configuration directives.
Allow accessing, from PHP's perspective, local files with LOAD DATA statements
Enable the ability to create persistent connections
Maximum of persistent connections that can be made. Set to 0 for unlimited.
The maximum number of MySQL connections per process.
The default TCP port number to use when connecting to
the database server if no other port is specified. If no
default is specified, the port will be obtained from the
MYSQL_TCP_PORT environment variable,
mysql-tcp entry in
/etc/services or the compile-time
MYSQL_PORT constant, in that order.
Win32 will only use the
The default socket name to use when connecting to a local database server if no other socket name is specified.
The default server host to use when connecting to the database server if no other host is specified. Doesn't apply in safe mode.
The default user name to use when connecting to the database server if no other name is specified. Doesn't apply in safe mode.
The default password to use when connecting to the database server if no other password is specified. Doesn't apply in safe mode.
Automatically reconnect if the connection was lost.
Available only with mysqlnd.
Users cannot set
through an API call or runtime configuration setting. Note that
if it were possible there would be differences between how
libmysqlclient and streams would interpret
the value of
This extension has no resource types defined.