Der native ODBC-Treiber von MSSQL Server für Linux und PHP 5.4

Ich habe Apache 2.2.16 und PHP 5.4.3 auf einem Linux Debian 6 x64.

Um den Native ODBC-Treiber des MSSQL-Servers für Linux zu installieren, befolge ich die folgenden Anweisungen:http://www.codesynthesis.com/~boris/blog/2011/12/02/microsoft-sql-server-odbc-driver-linux/

Ich habe meine odbc.ini-Datei folgendermaßen konfiguriert:

[mydsn]
Driver      = SQL Server Native Client 11.0
Database    = datbase
Server      = xxx.xxx.xxx.xxx,port

und meine odbcinst.ini so:

[SQL Server Native Client 11.0]
Description=Microsoft SQL Server ODBC Driver V1.0 for Linux
Driver=/opt/microsoft/sqlncli/lib64/libsqlncli-11.0.so.1790.0
Threading=1
UsageCount=1

Zum Testen führe ich den folgenden Befehl aus:

$ isql -v mydsn dbusername dbpassword

Und ich habe Erfolg:

+---------------------------------------+
| Connected!                            |
|                                       |
| sql-statement                         |
| help [tablename]                      |
| quit                                  |
|                                       |
+---------------------------------------+
SQL>

Dann können Sie mit phpize unixODBC unter PHP 5.4 folgendermaßen installieren: (Der erste Befehl, ln -s ..., wird verwendet, weil ./configure die Header von php am Standardspeicherort nicht finden kann.)

$ sudo ln -s /usr/include/php5 /usr/include/php
$ phpize
$ ./configure --with-pdo-odbc=unixODBC && make && make test
$ sudo make install

Auf meiner phpinfo () bekomme ich:

PDO support - enabled
PDO drivers - odbc

PDO Driver for ODBC (unixODBC) - enabled
ODBC Connection Pooling        - Enabled, strict matching

Jetzt ist es Zeit, alles mit einem PHP 5.4-Skript zu testen:

<?php
    ini_set('display_errors', 1);
    error_reporting(E_ALL);

    $conn = new PDO('odbc:DSN=mydsn;UID='.$usr.';PWD='.$psw);

    $query = 'select * from my_table'; 
    $stmt = $conn->prepare($query);
    $stmt->execute();
    while ($row = $stmt->fetch()) {
        echo "<pre>";
        print_r($row);
        echo "</pre>";
    }
?>

Aber es funktioniert nicht ... Ich habe folgende Fehlermeldung erhalten:

Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[01000] SQLDriverConnect: 0 
[unixODBC][Driver Manager]Can't open lib '/opt/microsoft/sqlncli/lib64/libsqlncli-11.0.so.1790.0' : file not found' 
in /var/www/testemssql.php:17 
Stack trace: 
#0 /var/www/testemssql.php(17): PDO->__construct('odbc:DSN=mydsn...') 
#1 {main} thrown in /var/www/testemssql.php on line 17

Meine Frage lautet also: Was ist passiert? Welche Konfiguration fehlt mir? Wie richte ich den Native ODBC-Treiber des MSSQL-Servers unter Linux und PHP 5.4 richtig ein?

Ps .: Wenn ich versuche, odbc_connect () zu verwenden, sagt PHP, dass die Funktion nicht existiert.

Antworten auf die Frage(5)

Ihre Antwort auf die Frage