PHP는 sqlSrv를 사용하여 Microsoft의 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
페클
프로그램은 PHP 설치 디렉터리 아래의 bin 디렉터리에 있습니다. PHP 디렉터리가 Linux 환경 변수에 없는 경우입니다. 또는 pecl 프로그램이 시스템 bin 경로에 연결되어 있지 않아 pecl 프로그램이 설치되지 않았다는 메시지가 표시됩니다.
sqlsrv를 설치하려면 unixODBC 지원이 필요하므로 설치 전에 unixODBC를 설치하지 않은 경우 unixODBC를 먼저 설치해야 하며 unixODBC는 SQLSERVER에 연결하기 위해 FreeTDS가 필요합니다. unixODBC는 일반 인터페이스 집합만 정의하고 특정 인터페이스가 없기 때문입니다. 구현 방법.
1. 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/에 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
구성 링크에서 찾을 수 있습니다. 2. 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 확장을 설치할 수 있습니다
3. PHP sqlsrv 확장 설치
pecl install sqlsrv
설치 후 php.ini에서 확장을 로드한 다음 아파치를 다시 시작해야 적용됩니다.
편집 후 화면에 출력되는 내용을 주목해주세요
이 글을 작성하는 환경은
우분투 16.04 LTS
PHP 7.0.27
유닉스ODBC 2.3.5
무료TDS 1.00.82
2018-03-02
PHP는 sqlSrv를 사용하여 Microsoft의 SQLSERVER 데이터베이스에 연결할 때 pdo_srv 확장자를 사용해야 합니다.
pdo_srv 확장 설치는 pecl을 사용하여 직접 설치할 수 있습니다.
pecl
프로그램은 PHP 설치 디렉토리 아래의 bin 디렉토리에 있습니다. PHP 디렉토리가 Linux 환경 변수에 없는 경우. 또는 pecl 프로그램이 시스템 bin 경로에 연결되어 있지 않아 pecl 프로그램이 설치되지 않았다는 메시지가 표시됩니다.
sqlsrv를 설치하려면 unixODBC 지원이 필요하므로 설치 전에 unixODBC를 설치하지 않은 경우 unixODBC를 먼저 설치해야 하며 unixODBC는 SQLSERVER에 연결하기 위해 FreeTDS가 필요합니다. unixODBC는 일반 인터페이스 집합만 정의하고 특정 인터페이스가 없기 때문입니다. 구현 방법.
1. 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/에 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
구성 링크에서 찾을 수 있습니다. 2. 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 확장을 설치할 수 있습니다
3. PHP sqlsrv 확장 설치
pecl install sqlsrv
설치 후 php.ini에서 확장을 로드한 다음 아파치를 다시 시작해야 적용됩니다.
편집 후 화면에 인쇄되는 내용에 주의하세요
위 내용은 Linux에서 sqlSrv를 사용하여 PHP를 Microsoft 데이터베이스에 연결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!