写本文时的环境是
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下PHP使用 PHP_ODBC 连接微软SQLSERVER数据库相关推荐

  1. linux上mysql允许远程连接,linux下mysql允许远程连接

    1. MySql安装教程 https://dev.mysql.com/doc/refman/5.7/en/linux-installation-yum-repo.html 默认情况下mysq的 roo ...

  2. JDBC连接微软SQLSERVER2000数据库

    文章来源:[url]http://quezhuning.spaces.live.com/Blog/cns!19493C442298AE31!465.entry[/url] 关于可恶的JDBC连接微软S ...

  3. Linux下修改mysql的root密码后数据库消失怎么处理

    Linux系统下如果没有通过password()函数修改mysql的root密码就会导致mysql数据库消失.有些人可能不知道而直接修改了mysql的root密码,于是产生了mysql数据库消失的问题 ...

  4. sqlserver 连接远程sqlserver数据库

    /* 2019-02-19 17:42:41 @hury sqlserver 连接远程sqlserver数据库 */ /*1.新增链接服务器*/ exec sp_addlinkedserver @se ...

  5. JDBC连接自定义sqlserver数据库实例名(多个实例)

    JDBC连接自定义sqlserver数据库实例名(多个实例) 2012年06月07日 12:14:48 阅读数:18097 java语言中,通过jdbc访问sqlserver2005(2008)数据库 ...

  6. 微软 无线键盘 linux,在Deepin系统中连接微软人体工学键盘蓝牙失效的解决方法...

    在Deepin操作系统要连接微软人体工学键盘蓝牙,但是失败,经过尝试,找到了解决方法,方法其实也简单,现在分享出来. 具体问题详情 首先,Ubuntu在安装双系统时会读取前一个系统的蓝牙信息,所以这个 ...

  7. 在linux下安装五笔和微软字体

    前提:RedHat9.0 ,以简体中文.KDE桌面登录linux. 一.安装fcitx五笔输入法: 试了网上的很多方法,发现鬼话连篇,根本装不上.最后,当我有一种自杀的冲动的时候,顶不住了,到外面买一 ...

  8. Linux下pppoe开机自动连接,Linux 系统 PPPoE 宽带连接设置方法

    Linux 系统 PPPoE 宽带连接设置方法 要在Linux下使用PPPOE认证方式,必须安装PPPOE客户端软件.下面说明如何进行安装: 本文以RedHat Linux 6.2为实验平台,其它平台 ...

  9. linux下 远程桌面连接,Unix/Linux下通过远程桌面连接Windows OS

    不知Microsoft出于什么考虑,在Windows XP中只允许一个Session通过远程桌面连接,如果一台XP为管理工作站,只有它能够访问后端的SAN Switch或存储系统,那么多人将无法同时使 ...

最新文章

  1. pytorch和jittor 程序对比
  2. bzoj 1877: [SDOI2009]晨跑 (网络流)
  3. 第四章4.1 4.2 快速傅里叶变换FFT-介绍
  4. “智网络 · 汇安全”绿盟科技智慧安全2.0全国巡讲上海首站开讲!
  5. centos 5 6安装本地yum源
  6. c 函数多次声明_C++核心准则C.132:不要没有理由就将函数声明为虚函数
  7. 前端学习(1568):封装一个面包屑导航
  8. 浏览网页时,手机显示手机被恶意攻击,不停震动,一直弹出应用要我下载,有没有问题?
  9. python黑色背景rbg_使用python PIL将RGB图像转换为纯黑白图像
  10. 千峰前端html个人笔记
  11. Python小工具之GUI倒计时提醒
  12. 视频教程-Windows程序设计应用开发-C/C++
  13. 分布式系统有哪些衡量指标?
  14. 某些特殊悼念日的时候,让个人网页风格变黑灰色
  15. Xcelsius 2008 sp3的新部件与新功能
  16. 微信的企业号开发流程
  17. 【仿淘宝首页】前端网页模板,大学生前端作业分享,html5+css电商网站模板,包含js动效
  18. java灌水bfs二叉树,二叉树的BFS搜索
  19. 【LeetCode-SQL】580. 统计各专业学生人数
  20. < Linux > 操作系统

热门文章

  1. 【软件测试】测试外包,我们该去吗?看看资深测试工程师的见解......
  2. 计算机应用水平测试app,全国职称计算机应用能力考试宝典
  3. 2021冬-不靠谱的老板-nps软件和云服务器实现内网穿透
  4. Evolve用什么征服了飞利浦产品设计?
  5. 2020年的总结和2021的目标
  6. 论恋爱对学习的促进作用
  7. win7软件安装时显示乱码解决方案
  8. 2019中国科技高光时刻:克隆杂交稻种子 海上发射火箭
  9. 群雄逐鹿“2011网民最喜爱的软件评选”
  10. pyqt5 多线程遇到的问题总结