freebsd下PHP连接Microsoft SQLServer的办法

发表于:2007-06-09来源:作者:点击数: 标签:
本人的系统配置:freebsd4.9 apache2.48 php4.3.4 freetds0.62.3 一、相关软件 freetds来源: 官方网站 http://www.freetds.org/ freetds0.62.3.tar.gz http://gd.tuwien.ac.at/visual/ibiblio/ALPHA/freetds/stable/ 或者在gogole上搜索. 这个软件能够用 Lin

本人的系统配置:freebsd 4.9
                        apache 2.48
                        php 4.3.4
                        freetds 0.62.3
一、相关软件

freetds 来源: 
官方网站  
http://www.freetds.org/
freetds0.62.3.tar.gz
http://gd.tuwien.ac.at/visual/ibiblio/ALPHA/freetds/stable/

或者在gogole上搜索.

这个软件能够用LinuxUnix连接MS SQLServer和Sybase数据库

二、安装配置步骤
第一步:编译安装freetds:
tar zxvf freetds-0.62.3.tar.gz(解压)
./configure –prefix=/usr/local/freetds --with-tdsver=8.0 --enable-msdblib
make
make install

第二步:重新编译PHP4
./configure [--with-apxs... --with-mysql...] ---enable-dbx(可选)  
--with-mssql=/usr/local/freetds
make
make install


第三步:配置freetds
ee /usr/local/freetds/etc/freetds.conf
去掉相关的注释
# A typical Microsoft SQL Server 2000 configuration
[MyServer2k]
       host = 192.168.101.2  (你的SQLServer机器名字或者IP地址)
       port = 1433
       tds version = 8.0

在这个配置文件中可以配置Windows域登陆或者SQLServer账号登陆两种方式
用phpinfo(),可以查看到如下信息:
mssql
MSSQL Support enabled 
Active Persistent Links  0  
Active Links  0  
Library version  7.0  

Directive Local Value Master Value 
mssql.allow_persistent On On 
mssql.batchsize 0 0 
mssql.compatability_mode Off Off 
mssql.connect_timeout 5 5 
mssql.datetimeconvert On On 
mssql.max_links Unlimited Unlimited 
mssql.max_persistent Unlimited Unlimited 
mssql.max_procs 25 25 
mssql.min_error_severity 10 10 
mssql.min_message_severity 10 10 
mssql.secure_connection Off Off 
mssql.textlimit Server default Server default 
mssql.textsize Server default Server default 
mssql.timeout 60 60 

第五步:在php中建立数据库连接 

<?php
$link = dbx_connect (mssql, "服务器", "数据库名", "用户", "密码")
            or die ("Could not connect");
print("Connected suclearcase/" target="_blank" >ccessfully");

dbx_close($link);
?>

或者
<?php
$link=mssql_connect("sqlserver",$your_username,$your_password) or die (“can’t Connect to Database”); 
echo $link; 
?>

在浏览器中运行上面脚本, 如果你得到一个link号那么恭喜,你已经配置好了,如果出现Call to undefined function: mssql_connect() 那说明仔细看上面的安装配置过程看你哪一步没有对。 
注意:sqlserver名称是在/usr/local/freetds/etc/freetds.conf中定义的host参数,如果你写的IP地址,就是IP地址。 
第六步:调试
如果出现不能连接,请在freetds配置文件中找到;dump file = /tmp/freetds.log这一行,注释掉前面的分号,再执行一下测试脚本,察看/tmp/freetds.log文件,它可以告诉你很多出错的信息帮助你排除问题。

 quakelee 回复于:2004-05-21 11:07:27
这还是dbx出现数年以来我第一次看到有人用dbx咧呵呵,怎么样dbx好用不?一直没机会试过
好久不作php编程了,我还真没试过
如果从unix上直接连接sql server是不能连接的么?我本来以为只要建个连接就可以了:(原来还要装个软件

 mzp 回复于:2004-05-21 14:27:29
[quote:4f04bb0b04="quakelee"]本来以为只要建个连接就可以了:(原来..........[/quote:4f04bb0b04]

怎么建联结?
 :em02: 
开个玩笑

freetds还是很不错的......

 dennis2 回复于:2004-05-22 02:30:10
[quote:dcfe773058="mzp"]
freetds还是很不错的......[/quote:dcfe773058]

没错。以前的版本还有些 bug (有些 bug 其实是功能的不完整),我想现在的版本应该好多了。

 zhengzeng 回复于:2004-06-06 14:07:17
搂主,我的情况和你差不多,我要在linux下访问sql server 2000
我在linux编译好了freetds,但用tsql执行select语句,中文全变成"?"

[root@backup bin]# ./tsql -Usa -SZXPCS
locale is "en_US"
locale charset is "ISO-8859-1"
Password:
Msg 2403, Level 16, State 0, Server OpenClient, Line 0
WARNING! Some character(s) could not be converted into client's character set. U
nconverted bytes were changed to question marks ('?').
Msg 5703, Level 0, State 1, Server JATELE, Line 0
Changed language setting to us_english.
1> quit

请问楼主碰到类似的问题吗?

谢谢先

 wanbb 回复于:2004-07-23 13:57:24
我也是要访问局域网内的mssql 2000,可我安装了freetds 0.62.4也没办法连上mssql2k,就是报mssql_connect函数错,另外我执行 freetds/bin/tsql 命令,系统说 command not found

原文转自:http://www.ltesting.net