Diese Erweiterung ist seit PHP 5.5.0 als veraltet markiert und wurde in PHP 7.0.0 entfernt werden. Verwenden Sie stattdessen die Erweiterungen MySQLi oder PDO_MySQL. Weitere Informationen finden Sie im Ratgeber MySQL: Auswahl einer API und den zugehörigen FAQ. Alternativen zu dieser Funktion umfassen:

Benutzen Sie die --with-mysql[=DIR] Konfigurationsoption um diese Erweiterung zu kompilieren. Der optionale Parameter [DIR] sollte dabei das Verzeichnis angeben in dem Sie MySQL installiert haben.

Die MySQL Erweiterung ist zwar kompatibel mit aktuellen MySQL Versionen, sie unterstützt aber nich mehr alle zusätzlichen Funktionalitäten die seit MySQL 4.1.0 hinzugekommen sind. Wenn Sie diese benötigen so verwenden Sie statt dessen die neuere MySQLi Erweiterung.

Wenn Sie beide MySQL Erweiterungen gleichzeitig nutzen wollen so sollten Sie diese mit der gleichen MySQL Client Library Version erstellen um mögliche Versionskonflikte zu vermeiden.

Installation auf Linux Systemen

Beachten sie: [DIR] ist der Pfad zu den MySQL Client Bibliothek Dateien (Header-Dateien und Bibliotheken), die von » MySQL heruntergeladen werden können.

Matrix der ext/mysql Kompilierungs-Optionen
PHP Version Standard Konfigurationsoptionen: mysqlnd Konfigurationsoptionen: libmysqlclient Changelog
4.x.x libmysqlclient Nicht verfügbar --without-mysql zum Deaktivieren MySQL standardmäßig aktiviert, MySQL Client Bibliotheken gebündelt
5.0.x, 5.1.x, 5.2.x libmysqlclient Nicht verfügbar --with-mysql=[DIR] MySQL ist nicht mehr standardmäßig aktiviert und die MySQL Client Bibliotheken sind nicht mehr gebündelt.
5.3.x libmysqlclient --with-mysql=mysqlnd --with-mysql=[DIR] mysqlnd ist nun verügbar
5.4.x mysqlnd --with-mysql --with-mysql=[DIR] mysqlnd ist nun der Standard

Installation auf Windows Systemen

PHP 5.0.x, 5.1.x, 5.2.x

MySQL ist nicht mehr automatisch aktiviert, Sie müssen die php_mysql.dll DLL in Ihrer php.ini selbst einbinden. PHP benötigt darüber hinaus Zugriff auf die MySQL Client Bibliothek. Eine Datei mit Namen libmysql.dll ist in der PHP Distribution für Windows enthalten, diese muss für Ihr Windows System über PATH zu finden sein damit Sie aus PHP heraus MySQL Datenbanken nutzen können. Der FAQ-Eintrag "Wie füge ich unter Windows PATH on Windows mein PHP-Verzeichnis hinzu?" bietet nähere Informationen zu diesem Thema. Sie können libmysql.dll zwar auch direkt in Ihr Windows Systemverzeichnis kopieren (da dieses immer im PATH Suchpfad enthalten ist), von diesem Vorgehen wird aber abgeraten.

Die PHP Direktive extension_dir sollte, wie bei jeder anderen Erweiterung auch, auf das Verzeichnis zeigen in dem die PHP Erweiterungen (wie php_mysql.dll) zu finden sind. Sie hier auch Manuelle Windows Installationsanweisungen. Ein typischer Wert für ein PHP 5 extension_dir ist c:\php\ext


Erscheint beim Start des Webservers eine Fehlermelding in der Art von "Unable to load dynamic library './php_mysql.dll'" so liegt das daran das php_mysql.dll und/oder libmysql.dll vom System nicht gefunden werden konnten.

PHP 5.3.0+

Der MySQL Native Treiber ist standardmäßig aktiviert. Binden sie php_mysql.dll ein, libmysql.dll wird jedoch nicht mehr benötigt oder genutzt.

MySQL Installationshinweise


Initialisierungsprobleme und Abstürze können vorkommen wenn Sie diese Erweiterung zusammen mit der recode Erweiterung verwenden. Nähere Informationen hierzu finden Sie im Handbuch-Abschnitt zu recode.


Wenn Sie andere Zeichensätze als den Standard latin Zeichensatz verwenden sollen so müssen Sie zum Erstellen der Erweiterung eine externe libmysqlclient verwenden die mit voller Zeichensatzunterstützung erstellt wurde. Die mit PHP 4 mitgelieferte libmysql bietet dies nicht.

add a note add a note

User Contributed Notes 7 notes

heneryville at gmail dot com
8 years ago
I believe that this is happens especially with Windows 7.  As far I I've been able to tell XP and Vista come with this line enabled, but windows 7 comments it out and notes that the DNS will handle this.
10 years ago
In windows systems, the same error "unable to load dynamic library php_mysql.dll" will happen, if there's an old version of the file in the "windows\system32" folder.
Either remove it or update it.
Steve in Weston-Super-Mare
7 years ago
I had problems when moving from a version of PHP that used the isapi dll to the fast cgi version. The script to register the script maps compained that there was already a script map in place.

I went to the IIS control panel, right clicked on websites and removed the php association in the Home Directory | Configuration screen.

However, the fastcgi script still complained about existing script map. Finally I tracked it down, I had to right click on Default Web Site and clear out the php mappings from there too.

Then it all worked, except that for some strange reason, the php.ini file that gets picked up is the one from my old PHP directory, not the latest upgrade one. But this can be detected by running phpinfo which shows the loaded php.ini file so I knew which one to amend with the fastcgi options.

Bit of a hassle to figure it all out but it does work in the end.
buzzr515 at gmx dot de
8 years ago
i've experienced a similar (if not the same) problem.

to enable the mysql_... and mysqli_... funtionality, i opened the php.ini file to uncomment the following lines:

but phpinfo() still stated that no mysql extensions were loaded.
i tried the fixes and suggestions above with no success.
so i invoked the windows shell and typed ("Path" environment variable set to the PHP & MySQL directories):
php.exe -m

this returned the following error: "PHP Startup: Unable to load dynamic library 'C:\php5\php_mysql.dll' - Module not found."

this told me that PHP didn't recognize what i thought was the extensions directory. it searched all other places first (sys-dir, workin'-dir, the MySQL "bin" dir because of the "Path" variable set, and even a curious directory "C:\php5" that doesn't even exist on my mashine) but not the expected "ext" directory.

so the fix was to go to "php.ini" again and uncomment the following line:

this fixed it for me.
so if module loading is done improperly, first of all check the "Path" environment variable and the "php.ini" file - especially the "extension_dir" config value - and check if all values are set to their correct values.

hope this helps any1.

OS: Win7 Ultimate x86
Apache v2.2.16
PHP v5.3.3
MySQL v5.1.50
amatsak at gmail dot com
9 years ago
I have experienced exactly the same problem as flo_stefi at yahoo dot com below. It appears that instead of loading libmysql.dll that came with the PHP package, the PHP engine was loading libmySQL.dll located in MySQL's bin directory, which was causing Apache to crash.

I fixed the problem by renaming MySQL's libmySQL.dll into libmySQL_renamed.dll. Now PHP loads the library that came with its package and everything works fine.
mail dot umlcat at gee mail dot com
6 years ago
Could not install mysql, on windows, had several conflicts or bugs.

In order to solve it:

* Used the "libmysql.dll" provided by PHP zip files, not the one that comes with Mysql, the mysql file had to be moved or deleted from its folder. Put it on the "apache/bin" folder, altought some use it in "windows" folder.

* Originally, moved "*mysql*.dll" files from its extension folder, and returned back.

* enabled mysql driver extensions in the "php.ini" file, but also enabled some extensions, that seemed not to be required, but, it did, like "php_openssl.dll" or "php_pdo.dll" on an early version of php.

Added the "PHPIniDir xxx"" to the "httpd.conf" apache config. file, where xxx is the path to the folder where the "php.ini" file is located, and make sure its the same.

Be warned, that this fixes, may help or not, for your installation, since there are many ways to configure the same thing (to solve a problem).
o dot kochetilov at gmail dot com
7 years ago
Please note that libmySQL.dll in MySQL bin directory should be renamed in order to use right library (that comes with PHP).
To Top