Linux下PHP使用 PHP_ODBC 连接微软SQLSERVER数据库
2018-03-02 14:44
309 查看
写本文时的环境是
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)、编译安装
网上有些教程里面写着–with-tdsver=8.0 ,我在编译的时候报错,具体支持的值可以看 ./configure –help 中with-tdsver的描述
安装完成后会在 /usr/local/freetds中生成一个etc目录,我们需要用到 freetds.conf文件。
c)、配置
配置freetds.conf文件。可以不用配置
不配置freetds.conf的方法可以见unixODBC的配置环节
更正: 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扩展即可使用
二、安装unixODBC
a)、下载
b)、编译安装
c)、配置
在 /etc/odbc.ini 中添加配置
网上有教程说编译安装的是在/usr/local/etc/odbc.ini
,虽然编译后有生成此文件,但配置在这个文件里面并不生效。还是要在/etc/odbc.ini中配置
更正: 可以使用/usr/local/bin/odbcinst -j 查看unixODBC的环境配置
以上配置完成后就可以测试了。
使用 unixODBC编译时生成的 isql 程序来测试。路径在 /usr/bin/isql
isql 的使用可以使用 isql –help 查看
配置如果没有错误,即可以看到连接到数据库了。就能使用sql语句查询东西了。
unixODBC配置完成后,就可以安装PHP扩展了
三、安装PHP的 pdo_odbc 扩展
安装完后需要去php.ini中加载扩展,然后重启apache才能生效。
注意看说编译完后的屏幕打印的内容
PHP命令示例:
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)、下载
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/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 中配置的 ?>
相关文章推荐
- 也谈Linux下使用freetds连接sqlserver数据库
- php程序无法使用localhost连接数据库解决方法(linux)
- 使用JDBC-ODBC连接SQLServer数据库后读取数据库中表的数据代码
- PHP使用ODBC连接数据库的方法
- Linux平台使用Freetds连接SQL Server服务器,兼容PHP和Laravel
- 通达OA二次开发 小飞鱼二次开发使用PHP连接SQLServer数据库(源码)
- Linux编译mssql扩展使用php连接sqlserver2008的使用步骤
- 使用PHP+FreeTDS在Linux下连接MS SQLServer数据库
- php使用odbc执行复杂函数遇到的问题,sql语句直接在sqlserver数据库中运行有结果,使用php总是为空
- linux下使用apache http server 连接 tomcat 达到使用直接apache一个服务端口就可访问php和jsp
- Linux下使用PHP连接SQL Server 2005
- php使用ODBC连接sqlserver问题
- 在微软报表服务中,使用odbc连接Sybase数据库,无法使用参数查询的问题我找到办法了
- Thinkphp使用PDO方式连接MSSQL2000、sqlserver数据库的方法,PHP版本是PHP5.2
- PHP使用sqlSrv连接微软数据库
- 使用win8.1 x64 office2010 php 使用 pdo_odbc 连接excel失败的问题
- PHP使用ODBC连接数据库的方法
- 关于php中使用odbc或者pdo连接sqlserver时如果查询条件中存在中文会导致查询失败的问题
- 使用PHP、FreeTDS在Linux下连接MS SQLServer数据库 [linux]
- Linux下使用PHP远程连接Oracle----笛风读书笔记系列