1. 程式人生 > >Linux下PHP使用 PHP_ODBC 連線微軟SQLSERVER資料庫

Linux下PHP使用 PHP_ODBC 連線微軟SQLSERVER資料庫

寫本文時的環境是
ubuntu 16.04 LTS
php 7.0.27
unixODBC 2.3.5
FreeTDS 1.00.82
2018-03-02日

PHP使用sqlSrv連線微軟的SQLSERVER資料庫時需要使用到擴充套件 pdo_srv。
pdo_srv 擴充套件安裝可以直接使用 pecl 安裝

(錯誤更新 pdo_srv 擴充套件只存在windows,Linux下需要使用odbc)

pecl
程式在PHP安裝目錄下的bin目錄中,如果你的PHP目錄不在Linux的環境變數中。或者你的pecl程式沒有連結到系統bin路徑下,會提示你pecl程式未安裝。

安裝sqlsrv 需要unixODBC的支援,所以在安裝之前如果你沒有安裝過unixODBC還需要先安裝unixODBC,而unixODBC需要FreeTDS來連線SQLSERVER,因為unixODBC只是定義了一套通用介面,並沒有具體的實現方法,

一、安裝FreeTDS
a)、下載

b)、編譯安裝

./configure --with-tdsver=auto --prefix=/usr/local/freetds --enable-msdblib --with-gnu-ld --enable-shared --enable-static --with-unixodbc=/usr/local
make make install

網上有些教程裡面寫著–with-tdsver=8.0 ,我在編譯的時候報錯,具體支援的值可以看 ./configure –help 中with-tdsver的描述

安裝完成後會在 /usr/local/freetds中生成一個etc目錄,我們需要用到 freetds.conf檔案。
c)、配置
配置freetds.conf檔案。可以不用配置

不配置freetds.conf的方法可以見unixODBC的配置環節

[global]
#全域性配置
tds version = auto
#更多的配置可以參考freetds官方文件,我這裡這樣配置已經夠用了
[servertag] #定義一個叫 servertag 的節點,這個節點的名稱可以自定義的,不是固定 #所有 # 符號的內容都可以不寫在配置檔案中,這裡只是註釋解釋用 #更多的細節配置看官方描述 #資料庫的連線IP地址 host = 192.168.9.12 #資料庫的埠 port = 1433 #連線時預設開啟的庫名,【可以不配置此項】 database = master #tds version 有全域性配置,這裡也可以不寫 tds version = auto

更正: Linux下的PHP可以通過編譯 pdo_dblib 來直接使用freetds來連線SqlServer
資料庫,連下文的unixODBC都不需要編譯

步驟:
進入PHP原始碼包 php-7.0.27/ext/pdo_dblib
/usr/local/c/bin/phpize #PHP完整路徑以自己編譯安裝為準
./configure –with-pdo-dblib=/usr/local/freetds –with-php-config=/usr/local/c/bin/php-config
編譯完成後,修改php.ini 新增pdo-dblib擴充套件即可使用

<?php
 $db = new PDO('dblib:host=xxxx;database=xxx","賬號","密碼");
?>

二、安裝unixODBC

a)、下載

  https://sourceforge.net/projects/unixodbc/files/unixODBC/
  http://www.unixodbc.org/
  以上兩個網站都可以下載到,建議到第二個官網下載吧。

b)、編譯安裝

./configure --prefix=/usr/local/unixODBC --includedir=/usr/include  --libdir=/usr/lib -bindir=/usr/bin --sysconfdir=/etc
make 
make install

c)、配置
在 /etc/odbc.ini 中新增配置

網上有教程說編譯安裝的是在/usr/local/etc/odbc.ini
,雖然編譯後有生成此檔案,但配置在這個檔案裡面並不生效。還是要在/etc/odbc.ini中配置

更正: 可以使用/usr/local/bin/odbcinst -j 檢視unixODBC的環境配置

[ODBC Data Sources]
#描述而已,沒有測過不寫行不行,理論上可行
SQLSERVER2018912 = 9.12 DB

[SQLSERVER2018912]
#Driver 指向的目錄是FreeTDS編譯生成的檔案,類似一個驅動檔案,稍後講解安裝方法
Driver = /usr/local/freetds/lib/libtdsodbc.so
Description  = 9.12 DB,文字描述
Trace = No
#Server 可以直接寫 FreeTDS的freetds.conf 中配置的servertag節點名
#使用freetds.conf配置時,port 也不用配置了。
#因為在此直接寫server IP時能配置的選項很少,而freetds.conf可以配置的細節更多
#此處我已經配置了IP,freetds.conf中其實就可以不用配置。只要安裝好freetds即可
Server = 192.168.9.12
Port = 1433
#7.4或auto應該都可以。沒有詳細研究過
TDS_Version = 7.4

[Default]
#全域性預設配置。理論上可以不寫
#同上,預設使用
Driver = /usr/local/freetds/lib/libtdsodbc.so

以上配置完成後就可以測試了。
使用 unixODBC編譯時生成的 isql 程式來測試。路徑在 /usr/bin/isql

/usr/bin/isql SQLSERVER2018912 資料庫賬號 密碼

isql 的使用可以使用 isql –help 檢視
配置如果沒有錯誤,即可以看到連線到資料庫了。就能使用sql語句查詢東西了。
unixODBC配置完成後,就可以安裝PHP擴充套件了

三、安裝PHP的 pdo_odbc 擴充套件

進入安裝目錄 php-7.0.27/ext/pdo_odbc
./configure --with-pdo-odbc=unixODBC --with-php-config=/usr/local/c/bin/php-config
make
makeinstall

安裝完後需要去php.ini中載入擴充套件,然後重啟apache才能生效。
注意看說編譯完後的螢幕列印的內容

PHP命令示例:

<?php
    $db = new PDO("odbc:SQLSERVER2018912","賬號","密碼");
    #SQLSERVER2018912 即unixODBC.ini 中配置的
?>