久久久久在线观看_又色又爽又黄的免费视频播放_一区中文字幕_日韩电影在线播放

今日頭條 焦點資訊 營銷之道 企業報道 淘寶運營 網站建設 軟件開發 400電話
  當前位置: 首頁 » 資訊 » 軟件開發 » 正文

Linux下PHP使用sqlSrv連接微軟數據庫的方法

放大字體  縮小字體 發布日期:2018-03-03  來源:企業800網  作者:新格網  瀏覽次數:225  【去百度看看】
核心提示:PHP使用sqlSrv連接微軟的SQLSERVER數據庫時需要使用到擴展 pdo_srv。 pdo_srv 擴展安裝可以直接使用 pecl 安裝
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的環境變量中;蛘吣愕膒ecl程序沒有鏈接到系統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中文網其它相關文章!

 
關鍵詞: sqlSrv,Linux,php
 
[ 資訊搜索 ]  [ 加入收藏 ]  [ 告訴好友 ]  [ 打印本文 ]  [ 違規舉報 ]  [ 關閉窗口 ]

 
0條 [查看全部]  相關評論

 
網站首頁 | 關于我們 | 聯系方式 | 使用協議 | 版權隱私 | 網站地圖 | 排名推廣 | 廣告服務 | 積分換禮 | 網站留言 | RSS訂閱 | 吉ICP備11001726號-6
企業800網 · 提供技術支持