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上搜索.
这个软件能够用
Linux和
Unix连接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 su
clearcase/" 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