首頁  >  文章  >  後端開發  >  Linux下PHP使用sqlSrv連接微軟資料庫的方法

Linux下PHP使用sqlSrv連接微軟資料庫的方法

小云云
小云云原創
2018-03-03 13:53:434989瀏覽

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

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

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

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

一、安裝FreeTDS
a)、下載

http://www.freetds.org/

b)、編譯安裝

./configure --with-tdsver=auto --prefix=/usr/local/freetds --enable-msdblib --with-gnu-ld --enable-shared --enable-static --with-unixodbc=/usr/localmake
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

二、安裝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=/etcmake 
make install

c)、設定
   在 /etc/odbc.ini 中加入設定

網路上有教學說編譯安裝的是在/usr/local/etc/odbc.ini
 ,雖然編譯後有產生此文件,但配置在這個文件裡面並不生效。還是要在/etc/odbc.ini配置

[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.12Port = 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的sqlsrv 擴展

pecl install sqlsrv

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

寫本文時的環境是  
 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 安裝

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

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

一、安裝FreeTDS
a)、下載

http://www.freetds.org/

b)、編譯安裝

./configure --with-tdsver=auto --prefix=/usr/local/freetds --enable-msdblib --with-gnu-ld --enable-shared --enable-static --with-unixodbc=/usr/localmake
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

二、安裝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=/etcmake 
make install

c)、設定
   在 /etc/odbc.ini 中加入設定

網路上有教學說編譯安裝的是在/usr/local/etc/odbc.ini
 ,雖然編譯後有產生此文件,但配置在這個文件裡面並不生效。還是要在/etc/odbc.ini配置

[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.12Port = 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的sqlsrv 擴展

pecl install sqlsrv

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

以上是Linux下PHP使用sqlSrv連接微軟資料庫的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn