本文在CentOS 7 64bit和Laravel 4.2环境测试通过。

 

1.下载源码并解压缩

  1. wget ftp://ftp.freetds.org/pub/freetds/stable/freetds-stable.tgz
  1. tar zxvf freetds-stable.tgz
  1. cd freetds-0.91

2.配置并生成makefile

  1. ./configure --with-tdsver=8.0 --enable-msdblib

3.编译安装

  1. make
  2. sudo make install

4.配置

默认安装的配置文件位于/usr/local/etc,在/usr/local/etc编辑freetds.conf 文件,默认为

  1. #   $Id: freetds.conf,v 1.12 2007/12/25 06:02:36 jklowden Exp $
  2. #
  3. # This file is installed by FreeTDS if no file by the same
  4. # name is found in the installation directory.
  5. #
  6. # For information about the layout of this file and its settings,
  7. # see the freetds.conf manpage "man freetds.conf".
  8. # Global settings are overridden by those in a database
  9. # server specific section
  10. [global]
  11. # TDS protocol version
  12. ;       tds version = 4.2
  13. # Whether to write a TDSDUMP file for diagnostic purposes
  14. # (setting this to /tmp is insecure on a multi-user system)
  15. ;       dump file = /tmp/freetds.log
  16. ;       debug flags = 0xffff
  17. # Command and connection timeouts
  18. ;       timeout = 10
  19. ;       connect timeout = 10
  20. # If you get out-of-memory errors, it may mean that your client
  21. # is trying to allocate a huge buffer for a TEXT field.
  22. # Try setting 'text size' to a more reasonable limit
  23. text size = 64512
  24. # A typical Sybase server
  25. [egServer50]
  26. host = symachine.domain.com
  27. port = 5000
  28. tds version = 5.0
  29. # A typical Microsoft server
  30. [egServer70]
  31. host = ntmachine.domain.com
  32. port = 1433
  33. tds version = 7.0

在文件的最后位置添加如下配置,即可连接SQL Server 2000

  1. [sql-server-2000]
  2. host = 192.168.182.9
  3. port = 1433
  4. tds version = 7.0

如果要连接SQL Server 2005或2008,需要添加以下配置

  1. [sql-server-2005]
  2. host = 192.168.70.1
  3. port = 1433
  4. tds version = 8.0

4.测试

  1. /usr/local/bin/tsql -S sql-server-2000 -U sa -P test

如果成功连接,将会出现以下提示

  1. locale is "zh_CN.UTF-8"
  2. locale charset is "UTF-8"
  3. using default charset "UTF-8"
  4. 1>

至此,FreeTDS已经是Linux具备连接SQL Server的功能了。

5.编译PHP扩展

PHP 5.4之后已经没有原生支持的SQL Server的驱动了,因此需要手动编译PHP源码的扩展添加对SQL Server的驱动支持。CentOS 7自带的是5.4版本的PHP,因此我们通过编译5.4版的PHP源码获得扩展。

目前CentOS yum源里最新的php是5.4.16,php可以通过yum安装到系统

  1. sudo yum install php php-devel php-fpm php-common php-mysql php-pdo libzip

php官网上最新的5.4版本是 5.4.39,下载源码到本地

  1. wget http://cn2.php.net/distributions/php-5.4.39.tar.gz

解压并进入扩展目录

  1. tar zxvf php-5.4.39.tar.gz
  2. cd php-5.4.39/ext/mssql

使用phpize生成configure脚本文件

  1. phpize

生成makefile

  1. ./configure

编译

  1. make

编译之后将会在modules子目录生成mssql.so扩展文件。复制扩展文件到php的扩展文件目录

  1. sudo cp modules/mssql.so /usr/lib64/php/modules/

在/etc/php.d目录下新建mssql.ini 文件,输入以下内容

  1. ; Enable mssql extension module
  2. extension=mssql.so

这样PHP就能加载SQL Server驱动了。使用如下代码测试PHP连接SQL Server。

  1. <?php
  2. header("Content-type: text/html; charset=utf-8");
  3. $msdb=mssql_connect("sql-server-2000","sa","test");
  4. if (!$msdb) {
  5. echo "connect sqlserver error";
  6. exit;
  7. }
  8. mssql_select_db("msdb",$msdb);
  9. $result = mssql_query("SELECT top 5 * FROM employee", $msdb);
  10. while($row = mssql_fetch_array($result)) {
  11. var_dump($row);
  12. }
  13. mssql_free_result($result);
  14. ?>

代码中的数据库配置信息可以替换成别的。测试命令如下

  1. php -f test-mssql.php

成功执行后将会打印出数据库表中记录数据。

目前原生PHP代码已经可以连接SQL Server了,但是Laravel还是不行,还需要再编译生成一个pdo_dblib.so扩展驱动。

6.编译pdo_dblib.so扩展适配Laravel

  1. cd php-5.4.39/ext/pdo_dblib
  2. ./configure
  3. make
  4. sudo cp modules/pdo_dblib.so /usr/lib64/php/modules/

再到/etc/php.d下新建pdo_dblib.ini,输入以下内容

  1. ; Enable pdo_dblib extension module
  2. extension=pdo_dblib.so

再编辑Laravel的app/config/database.php文件,将sqlsrv区域改为一下形式

  1. 'sqlsrv' => array(
  2. 'driver'   => 'sqlsrv',
  3. 'host'     => 'sql-server-2000',
  4. 'database' => 'msdb',
  5. 'username' => 'sa',
  6. 'password' => 'test',
  7. 'prefix'   => '',
  8. ),

这样Laravel也可以连接SQL Server了。

Linux平台使用Freetds连接SQL Server服务器,兼容PHP和Laravel的更多相关文章

  1. Linux下用freetds执行SQL Server的sql语句和存储过程

    Linux下用freetds执行SQL Server的sql语句和存储过程 http://www.linuxidc.com/Linux/2012-06/61617.htm freetds相关 http ...

  2. 在非SQL客户端使用命令行方式定期连接SQL Server 服务器并模拟用户查询操作,同时输出信息内容

    一个很长的标题,实现的功能就是尽量使用非人力的方式模拟人去做一件事情,为了便于记录,将他们输出成文件方便查阅. 图形界面方式,使用微软自己的ConnMaker.exe,或者Microsoft 数据连接 ...

  3. 使用JDBC连接SQL Server

    源文:http://bbs.bc-cn.net/dispbbs.asp?boardid=12&id=140292 整理:秋忆 接触Java或者JSP,难免会使用到数据库SQL Server 2 ...

  4. JDBC连接SQL Server 2005步骤详解

    一.设置SQL Server服务器:    1.“开始” → “程序” → “Microsoft SQL Server 2005” → “配置工具” → “SQL Server Configurati ...

  5. Sql Server 服务器名称\实例名称 无法连接 Server Name\Instance Name

      解决步骤: 1:  Sql Server是否已经启动. 2:  检查Sql Server服务器是否开启TCP/IP协议. 侦听的默认端口为1433          3:     ping 数据库 ...

  6. Windows 2008服务器环境PHP连接SQL Server数据库的配置及连接方法

    背景: PHP程序常用的数据库是Mysql数据库,但是由于实际项目需要,要求PHP网站连接SQL Server数据库查询一些必要信息.因此,本文就来给大家介绍一下如何安装及配置PHP扩展,可以实现PH ...

  7. sql server 2008 64位连接sql 2000服务器的时候出现

    来源 https://blog.csdn.net/loeley/article/details/7095741 sql server 2008 64位连接sql 2000服务器的时候出现以下提示: 链 ...

  8. ASP .Net Core 在 CentOS8 ARM 下连接 SQL Server 2008 R2(Hypervisor)

    本文主要记录在 ARM 系统下无法连接SQL Server 2008 R2 的解决过程. 解决方案是使用 ODBC 的方式连接数据库,进行操作. 手上有公司的华为鲲鹏云计算 ARM 架构的 CentO ...

  9. php连接sql server

    这两天有个php连接sql server的项目,顺便学习学习sql server  说明: 1:PHP5.2.x本身有个php_mssql.dll的扩展用来连接Sql server,但是这个dll只是 ...

随机推荐

  1. Vue打包项目图片等静态资源的处理

    项目打包,默认是打包在根目录下面的.当然我们可以通过设置,打包到任意子目录中去. 但是,当项目中引入资源的,比如:引入图片资源.js资源.或者字体图标之类的.那么可能在这个中间又会踩坑. 1.在vue ...

  2. Python爬虫之一 PySpider 抓取淘宝MM的个人信息和图片

    ySpider 是一个非常方便并且功能强大的爬虫框架,支持多线程爬取.JS动态解析,提供了可操作界面.出错重试.定时爬取等等的功能,使用非常人性化. 本篇通过做一个PySpider 项目,来理解 Py ...

  3. [转]JQuery - Sizzle选择器引擎原理分析

    原文: https://segmentfault.com/a/1190000003933990 ---------------------------------------------------- ...

  4. CSS学习(九)-CSS背景

    一.理论: 1.background-break  a.bounding-box 背景图像在整个内联元素中进行平铺 b.each-box 背景图像在行内中进行平铺 c.continuous 下一行的背 ...

  5. projecteuler----&gt;problem=10----Summation of primes

    title: The sum of the primes below 10 is 2 + 3 + 5 + 7 = 17. Find the sum of all the primes below tw ...

  6. Discuz常见小问题2-如何清空,删除,清除全部DIY的数据

    如果所有diy都不想要了,手动清空_common_block._common_diy_data与_common_template_block表,然后删除\data\diy\下的所有子文件夹,保证你以前 ...

  7. 倍福TwinCAT(贝福Beckhoff)常见问题(FAQ)如何修改标准驱动器编码器分辨率

    在某个轴的Enc上双击,可以修改Scaling Factor Numerator     更多教学视频和资料下载,欢迎关注以下信息: 我的优酷空间: http://i.youku.com/acetao ...

  8. Python自省 type(),dir(),getattr(),hasattr(),isinstance().

    Python自省 这个也是python彪悍的特性. 自省就是面向对象的语言所写的程序在运行时,所能知道对象的类型.简单一句就是运行时能够获得对象的类型.比如type(),dir(),getattr() ...

  9. node了解

    学习资料 廖雪峰的官方网站—node.js Node.js 中文网:http://nodejs.cn/ Node.js 教程(菜鸟教程):http://www.runoob.com/nodejs/no ...

  10. vue - utils for extract-text-webpack-plugin

    描述:将包或包中的文本提取到单独的文件中, 点击查看官网详情: https://www.npmjs.com/package/extract-text-webpack-plugin