downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

Configurația la rulare> <Necesități
[edit] Last updated: Thu, 12 Jan 2012

view this page in

Instalarea

Pentru compilare, pur și simplu utilizați opțiunea de configurare --with-mysql[=DIR] , unde parametrul opțional [DIR] indică directorul unde a fost instalat MySQL.

Cu toate că această extensie MySQL este compatibilă cu MySQL 4.1.0 și versiunile ulterioare, ea nu susține funcționalitatea suplimentară oferită de aceste versiuni. Pentru aceasta utilizați extensia MySQLi.

Dacă doriți să instalați extensia mysql împreună cu extensia mysqli, trebuie să utilizați aceeași bibliotecă-client pentru a evita conflicte.

Instalarea pe sisteme Linux

PHP 4

Opțiunea --with-mysql este activată implicit. Acest comportament implicit poate fi dezactivat cu opțiunea de configurare --without-mysql . Dacă MySQL este activat fără specificarea căii către directorul DIR de instalare al MySQL, PHP va utiliza bibliotecile-client MySQL încorporate.

Utilizatorii care rulează alte aplicații care utilizează MySQL (spre exemplu, auth-mysql) nu ar trebui să utilizeze biblioteca furnizată, dar să specifice calea către directorul de instalare al MySQL, în felul următor: --with-mysql=/path/to/mysql . Aceasta va forța PHP să utilizeze bibliotecile-client instalate de MySQL, evitând în acest fel orice conflicte.

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

MySQL nu este activat implicit, și nici biblioteca MySQL nu este furnizată cu PHP. Citiți acest FAQ pentru a afla detalii despre cauze. Utilizați opțiunea de configurare --with-mysql[=DIR] pentru a include susținerea MySQL. Puteți descărca antete și biblioteci de pe » MySQL.

PHP 5.3.0+

În PHP 5.3.0 și ulterior extensiile bazelor de date MySQL utilizează implicit driver-ul nativ MySQL. Aceasta înseamnă că biblioteca-client MySQL (libmysql) nu mai este necesară pentru a susține conexiuni la baze de date MySQL. Extensiile mysql, mysqli și PHP_PDO_MYSQL sunt toate activate implicit în PHP 5.3.0+, și toate utilizează implicit driver-ul nativ MySQL. În orice caz nu sunt necesari alți pași de instalare pentru a utiliza aceste extensii, cu toate că ar fi bine să stabiliți unele preferințe în php.ini în dependență de necesitățile dumneavoastră.

Instalarea pe sisteme Windows

PHP 4

Extensia PHP MySQL este compilată în PHP.

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

MySQL nu mai este activat implicit, deci biblioteca DLL php_mysql.dll trebuie activată în php.ini. De asemenea PHP are nevoie de access la biblioteca-client MySQL. Un fișier numit libmysql.dll este inclus în distributivul PHP pentru Windows și pentru ca PHP să poată comunica cu MySQL, acest fișier trebuie să fie disponibil în căile din variabila PATH a sistemului Windows. Accesați și FAQ întitulat "Cum să adaug directorul PHP în variabila PATH din Windows" pentru informații despre cum să realizați acest lucru. Cu toate că copierea libmysql.dll în directorul de sistem al Windows de asemenea funcționează (deoarece directorul de sistem se află implicit înscris în variabila PATH a sistemului), aceasta nu e recomandabil.

Ca și în cazul activării oricărei extensii PHP (cum ar fi php_mysql.dll), directiva PHP extension_dir trebuie să fie stabilită către directorul unde sunt amplasate extensiile PHP. Accesați de asemenea Instrucțiunile de instalare manuală în Windows. O valoare-exemplu a extension_dir pentru PHP 5 ar putea fi c:\php\ext

Notă:

Dacă la startarea server-ului web apare o eroare similară cu aceasta: "Unable to load dynamic library './php_mysql.dll'" ("Nu s-a reușit încărcarea bibliotecii dinamice './php_mysql.dll'"), aceasta este din cauza că php_mysql.dll și/sau libmysql.dll nu pot fi găsite de către sistem.

PHP 5.3.0+

Vă rugăm să vă referiți la aceste note în legătură cu instalarea susținerii MySQL în PHP 5.3.0 și ulterior.

Note la instalarea MySQL

Avertizare

Pot fi întâlnite prăbușiri și alte probleme la startarea PHP atunci când această extensie este încărcată împreună cu extensia recode. Accesați extensia recode pentru informații suplimentare.

Notă:

Dacă aveți nevoie se seturi de caractere ce diferă de latin (implicit), trebuie să instalați biblioteca externă libmysql compilată pentru a susține setul de caractere dorit.



Configurația la rulare> <Necesități
[edit] Last updated: Thu, 12 Jan 2012
 
add a note add a note User Contributed Notes Instalarea
Steve in Weston-Super-Mare 27-Jul-2011 04:55
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.
o dot kochetilov at gmail dot com 30-Apr-2011 06:39
Please note that libmySQL.dll in MySQL bin directory should be renamed in order to use right library (that comes with PHP).
buzzr515 at gmx dot de 03-Sep-2010 03:13
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:
;extension=php_mysql.dll
;extension=php_mysqli.dll
;extension=php_pdo_mysql.dll

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:
;extension_dir="ext"

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
titus at antennasystems dot com 28-Jun-2010 04:00
I ran into the soon to be infamous problem of upgrading to PHP 5.3.x.
The way I found to resolve the issue was to

1: Do "mysql_upgrade" on the server (to make MySQL compliant with MySQL 4.1+).

2: Modify my.cf to not use old passwords:
(Just comment out "old_passwords=1")
#old_passwords=1

3: Change the root password so you can properly connect to the server:
SET PASSWORD FOR 'root'@'localhost' = PASSWORD('enter_new_password_here');

http://dev.mysql.com/doc/refman/5.1/en/old-client.html
http://tinyurl.com/mysql-old-password

Taken from http://www.comsiteconstruction.com/blueonyx-modifications
samishiikihaku23 at gmail dot com 17-Jun-2010 05:36
I've checked all the 5.3 distribution files from http://windows.php.net/ for the "libmysql.dll" file that this article claims is in the distributions.

None of the 5.3 dist. supplies "libmysql.dll". Download the recent 5.2 release for the file.
heneryville at gmail dot com 30-Apr-2010 07:32
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.
jez300 09-Mar-2010 10:34
Windows 7 / Vista:

This took me hours to realise... If you receive the message:
Warning: mysql_connect(): [2002] A connection attempt failed because the connected party did not (trying to connect via tcp://localhost:3306)

You may need to map localhost to your IP address (127.0.0.1) which is used to find your Mysql server.

Edit {systemdrive}:\Windows\System32\drivers\etc

Make sure "127.0.0.1       localhost" isn't commented out with # at the begining of the line!

-----

You may also like to know that if you change from MySQL 32 bit to 64 bit and the Mysql service wont start you may need to rename or delete your Mysql data
{systemdrive}:\ProgramData\x MySQL\MySQL Server 5.1\data

Regards,

Jez.
amatsak at gmail dot com 21-Jun-2009 08:46
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.
flo_stefi at yahoo dot com 31-Mar-2009 10:10
I had a problem to make mysql work with php on Windows. Using mysql-5.1.32-win32 and php-5.2.9-1-win32-installer I've installed mysql and php. All seemed to be ok (phpinfo displayed the right information) but when running a basic script mysql_connect(..) the apache ends with a stupid error like "[Wed Apr 01 14:44:05 2009] [notice] Parent: child process exited with status 3221225477 -- Restarting.".
I manage to fix it by using instead of libMySQL.dll from mysql package another version (libmysql.dll) I had from a previous installation.
lobbanhousehold at gmail dot com 11-Feb-2009 12:05
I figured my problem why php and mysql weren't working together even though they worked independent of each other. PHP was configured with IIS 5.1 (XP) using the php5isapi.dll file.

I also set system variables in PATH adding the locations of both php and mysql folders. I also moved the mysql DLL files from ext folder to the root folder of php.

I discovered that php would not work with mysql if php folder was not located on the C:\ (i.e. C:\php). I also renamed the libmysql.dll that came with mysql so that the system would not see it, and moved the one that came with php to C:\WINDOWS\system32.

After I did this last paragraph i was able to see MySQL and MySQLi sections listed in phpinfo() which indicates MySQL is finally enabled
admin at kobashicomputing dot com 01-Nov-2008 05:02
Unfortunately this one bit me for a good half day.

Placing libmysql.dll in the php/ext directory did not work. I tested this under 5.6.2. You need to have it somewhere in the PATH or in SYSTEM or SYSTEM32. But to me this is very silly to force the user to have to setup environment variables or move DLLs around. It shouldn't have to go that far and be the responsibility of the setup program and/or developer.

I really think this issue could be solved doing this:
1) Installer/distribution bundle all three files together under one directory (ext) - php_mysql.dll/php_mysqli.dll/libmysql.dll

2) Developer goes into php_mysql.dll/php_mysqli.dll and in DllMain() on DLL_PROCESS_ATTACH:
  LoadLibrary ("./libmysql.dll");

Then you don't have to deal with this problem and neither do your users.

Kerry Kobashi
rogerc at clubsites dot net 20-Jul-2008 01:05
This error also occurs if the windows path entry for an older version of MYSQL appears before the path entry for a late version of php.  In which case the version of libmysl.dll in the MySQL bin directory will be found before the one bundled with php.  Reversing the system path entries so php is first fixes this problem.  e.g.
PATH= ...  c:\php;C:\Program Files\MySQL\MySQL Server 4.1\bin
Mahesh 12-Jun-2008 08:37
In windows systems, the error "unable to load dynamic library php_mysql.dll" also happens if there's an old version of the file libmysql.dll in the "windows\system32" folder.
jonnus 11-May-2008 11:42
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.

 
show source | credits | stats | sitemap | contact | advertising | mirror sites