php连接mssql的一些相关经验及注意事项
程序员文章站
2022-11-24 09:54:52
为了能让php连接mssql,系统需要安装mssql,php,且在php.ini中的配置中,将 ;extension=php_mssql.dll前面的;去掉 1.连接mss...
为了能让php连接mssql,系统需要安装mssql,php,且在php.ini中的配置中,将
;extension=php_mssql.dll前面的;去掉
1.连接mssql
$conn=mssql_connect("实例名或者服务器ip","用户名","密码");
//测试连接
if($conn)
{
echo"连接成功";
}
2.选择要连接的数据库
mssql_select_db("dbname");
3.执行查询
$rs=mssql_query("selecttop1id,usernamefromtbname",$conn);
或者直接执行update,insert等语句,可以不用为返回结果赋值
mssql_query("updatetbnamesetusername='niunv'whereid=1");
4.获取记录集行数
echomssql_num_rows($rs);
5.获取记录集
if($row=mssql_fetch_array($rs))
{
$id=$row[0];//获取id字段值
$username=$row[1];//获取username字段值
}
6.获取新增记录的id
将id字段设置为identity字段,执行insert语句以后,就会产生一个@@identity全局变量值,查询出来就是最后一条新增记录的id了.
mssql_query("insertintotbname(username)values('nv')",$conn);
$rs=mssql_query("select@@identityasid",$conn);
if($row=mssql_fetch_array($rs))
{
echo$row[0];
}
7.释放记录集
mssql_free_result($rs);
8.关闭连接
mssql_close($conn);
注:用php操作mssql比在asp连接mysql要简单,所以,当需要mssql与mysql并存时,用php连接mssql来操作mysql与mssql并存比较简单好用.如果是asp连接mysql,需要安装一个mysql驱动,默认windows的odbc没有安装,很遗憾...
1.在web服务器上至少安装了mssql的客户端
2.打开php.ini把;extension=php_mssql.dll前面的分号去掉
有必要话:需要制定extension_dir
3.推荐使用php<=4.0.9<=5.0.3目前我还没有连接成功过4.010和5.0.3
4.数据库的连接分页可以到phpe.net上获取到相应的class
下面是我根据那里修改的一个class
<?php
/**
*mssql数据库连接类
**/
classsql{
var$server;
var$username;
var$password;
var$database;
var$linkid=0;
var$queryresult;
var$lastinsertid;
var$pagenum=0;//分页用---共有几条数据
var$er;
/**
*构造函数
**/
functionsql($server='',$username='',$password='',$database=''){
$this->server=$server;
$this->username=$username;
$this->password=$password;
$this->database=$database;
}
/**
*数据库连接
**/
functiondb_connect(){
$this->linkid=mssql_pconnect($this->server,$this->username,$this->password);
if(!$this->linkid){
$this->er="db_connect($this->server,$this->username,$this->password)error";
return0;
}
if(!mssql_select_db($this->database,$this->linkid)){
$this->er="mssql_select_db($this->database,$this->lastinsertid)error";
return0;
}
return$this->linkid;
}
/**public
*function:checkthedatabase,ifexistthenselect
*exist:return1
*notexist:return0
*/
functionselectdatabase(){
if(mssql_select_db($this->database))
return1;
else
return0;
}
/**
*数据操作
**/
functionquery($str){
if($this->linkid==0){
$this->er="数据库还没有连接!!";
}
$this->queryresult=mssql_query($str);
//$this->queryresult=mssql_query($str,$this->linkid);
if(!$this->queryresult){
$this->er="$str.没有操作成功,queryerror!!";
return0;//****************对于php4.3.9以上版本的错误用1
}
return$this->queryresult;
}
/**
*数据获取
**/
functionfetch_array($result){
if($result!="")$this->queryresult=$result;
$rec=mssql_fetch_array($this->queryresult);
if(is_array($rec)){
return$rec;
}
//$this->er="没有获取数据!";
return0;
}
/**public
*function:freethequeryresult
*successreturn1
*failed:return0
*/
functionfreeresult($result=""){
if($result!="")$this->queryresult=$result;
returnmssql_free_result($this->queryresult);
}
/**
*获取影响的的行数
*获取操作过的行数
**/
functionnum_rows($result=""){
if($result!=""){
$this->queryresult=$result;
$row=mssql_num_rows($this->queryresult);
return$row;
}
}
/**
*获取查询结果---多个
**/
functionresult_ar($str=''){
if(empty($str)){
return0;
}
$back=array();
$this->queryresult=$this->query($str);
while($row=$this->fetch_array($this->queryresult)){
$back[]=$row;
}
return$back;
}
/**
*数据库信息分页
*$result数据库操作
*str==sql语句
*page==第几页
*shownum==显示几页
*/
functionpage($str,$page=0,$shownum=5){
$back=array();//返回数据
$maxnum=0;
if($str==""){
$this->er="没有数据";
return0;
}
$this->queryresult=$this->query($str);
if($this->queryresult){
if($page==""){
$nopa=0;
}else{
$nopa=($page-1)*$shownum;
if($nopa<0){
$nopa=0;
}
}
$maxnum=$this->num_rows($this->queryresult);
$k=0;
$i=0;
$dd=$this->fetch_array($this->queryresult);
while($dd&&$nopa<=$maxnum&&$i<$shownum){
if($nopa>=$maxnum)$nopa=$maxnum;
mssql_data_seek($this->queryresult,$nopa);
$row=$this->fetch_array($this->queryresult);
$nopa++;
$i++;
$back[]=$row;
if($nopa>=$maxnum){
break;
}
}
}
$this->pagenum=$maxnum;
return$back;
}
/**
*分页的html页码
*/
functionpage_html($datanum=0,$page=1,$shownum=3,$web,$post=''){
if($datanum==0){
$back="没有要查询的数据";
}else{
if($shownum<=0){
$shownum=3;
}
if($page<=0){
$page=1;
}
if(empty($web)){
$web="#";
}
$pagenum=ceil($datanum/$shownum);
if($page<=1){
$top="首页<<";
}else{
$top="<ahref='".$web."?page=0&".$post."'target='_self'>首页<<</a>";
}
if($page!==1){
$uppage="<ahref='".$web."?page=".($page-1)."&".$post."'target='_self'>上一页</a>";
}else{
$uppage="上一页";
}
if($page<$pagenum){
$downpage="<ahref='".$web."?page=".($page+1)."&".$post."'target='_self'>下一页</a>";
}else{
$downpage="下一页";
}
if($page==$pagenum){
$foot=">>尾页";
}else{
$foot="<ahref='".$web."?page=".$pagenum."&".$post."'target='_self'>>>尾页</a>";
}
$back=<<<eot
共$pagenum页
第$page/$pagenum页$top $uppage $downpage $foot
eot;
}
return$back;
}
}//endclass
?>
;extension=php_mssql.dll前面的;去掉
1.连接mssql
复制代码 代码如下:
$conn=mssql_connect("实例名或者服务器ip","用户名","密码");
//测试连接
if($conn)
{
echo"连接成功";
}
2.选择要连接的数据库
复制代码 代码如下:
mssql_select_db("dbname");
3.执行查询
复制代码 代码如下:
$rs=mssql_query("selecttop1id,usernamefromtbname",$conn);
或者直接执行update,insert等语句,可以不用为返回结果赋值
mssql_query("updatetbnamesetusername='niunv'whereid=1");
4.获取记录集行数
复制代码 代码如下:
echomssql_num_rows($rs);
5.获取记录集
复制代码 代码如下:
if($row=mssql_fetch_array($rs))
{
$id=$row[0];//获取id字段值
$username=$row[1];//获取username字段值
}
6.获取新增记录的id
将id字段设置为identity字段,执行insert语句以后,就会产生一个@@identity全局变量值,查询出来就是最后一条新增记录的id了.
复制代码 代码如下:
mssql_query("insertintotbname(username)values('nv')",$conn);
$rs=mssql_query("select@@identityasid",$conn);
if($row=mssql_fetch_array($rs))
{
echo$row[0];
}
7.释放记录集
复制代码 代码如下:
mssql_free_result($rs);
8.关闭连接
复制代码 代码如下:
mssql_close($conn);
注:用php操作mssql比在asp连接mysql要简单,所以,当需要mssql与mysql并存时,用php连接mssql来操作mysql与mssql并存比较简单好用.如果是asp连接mysql,需要安装一个mysql驱动,默认windows的odbc没有安装,很遗憾...
1.在web服务器上至少安装了mssql的客户端
2.打开php.ini把;extension=php_mssql.dll前面的分号去掉
有必要话:需要制定extension_dir
3.推荐使用php<=4.0.9<=5.0.3目前我还没有连接成功过4.010和5.0.3
4.数据库的连接分页可以到phpe.net上获取到相应的class
下面是我根据那里修改的一个class
复制代码 代码如下:
<?php
/**
*mssql数据库连接类
**/
classsql{
var$server;
var$username;
var$password;
var$database;
var$linkid=0;
var$queryresult;
var$lastinsertid;
var$pagenum=0;//分页用---共有几条数据
var$er;
/**
*构造函数
**/
functionsql($server='',$username='',$password='',$database=''){
$this->server=$server;
$this->username=$username;
$this->password=$password;
$this->database=$database;
}
/**
*数据库连接
**/
functiondb_connect(){
$this->linkid=mssql_pconnect($this->server,$this->username,$this->password);
if(!$this->linkid){
$this->er="db_connect($this->server,$this->username,$this->password)error";
return0;
}
if(!mssql_select_db($this->database,$this->linkid)){
$this->er="mssql_select_db($this->database,$this->lastinsertid)error";
return0;
}
return$this->linkid;
}
/**public
*function:checkthedatabase,ifexistthenselect
*exist:return1
*notexist:return0
*/
functionselectdatabase(){
if(mssql_select_db($this->database))
return1;
else
return0;
}
/**
*数据操作
**/
functionquery($str){
if($this->linkid==0){
$this->er="数据库还没有连接!!";
}
$this->queryresult=mssql_query($str);
//$this->queryresult=mssql_query($str,$this->linkid);
if(!$this->queryresult){
$this->er="$str.没有操作成功,queryerror!!";
return0;//****************对于php4.3.9以上版本的错误用1
}
return$this->queryresult;
}
/**
*数据获取
**/
functionfetch_array($result){
if($result!="")$this->queryresult=$result;
$rec=mssql_fetch_array($this->queryresult);
if(is_array($rec)){
return$rec;
}
//$this->er="没有获取数据!";
return0;
}
/**public
*function:freethequeryresult
*successreturn1
*failed:return0
*/
functionfreeresult($result=""){
if($result!="")$this->queryresult=$result;
returnmssql_free_result($this->queryresult);
}
/**
*获取影响的的行数
*获取操作过的行数
**/
functionnum_rows($result=""){
if($result!=""){
$this->queryresult=$result;
$row=mssql_num_rows($this->queryresult);
return$row;
}
}
/**
*获取查询结果---多个
**/
functionresult_ar($str=''){
if(empty($str)){
return0;
}
$back=array();
$this->queryresult=$this->query($str);
while($row=$this->fetch_array($this->queryresult)){
$back[]=$row;
}
return$back;
}
/**
*数据库信息分页
*$result数据库操作
*str==sql语句
*page==第几页
*shownum==显示几页
*/
functionpage($str,$page=0,$shownum=5){
$back=array();//返回数据
$maxnum=0;
if($str==""){
$this->er="没有数据";
return0;
}
$this->queryresult=$this->query($str);
if($this->queryresult){
if($page==""){
$nopa=0;
}else{
$nopa=($page-1)*$shownum;
if($nopa<0){
$nopa=0;
}
}
$maxnum=$this->num_rows($this->queryresult);
$k=0;
$i=0;
$dd=$this->fetch_array($this->queryresult);
while($dd&&$nopa<=$maxnum&&$i<$shownum){
if($nopa>=$maxnum)$nopa=$maxnum;
mssql_data_seek($this->queryresult,$nopa);
$row=$this->fetch_array($this->queryresult);
$nopa++;
$i++;
$back[]=$row;
if($nopa>=$maxnum){
break;
}
}
}
$this->pagenum=$maxnum;
return$back;
}
/**
*分页的html页码
*/
functionpage_html($datanum=0,$page=1,$shownum=3,$web,$post=''){
if($datanum==0){
$back="没有要查询的数据";
}else{
if($shownum<=0){
$shownum=3;
}
if($page<=0){
$page=1;
}
if(empty($web)){
$web="#";
}
$pagenum=ceil($datanum/$shownum);
if($page<=1){
$top="首页<<";
}else{
$top="<ahref='".$web."?page=0&".$post."'target='_self'>首页<<</a>";
}
if($page!==1){
$uppage="<ahref='".$web."?page=".($page-1)."&".$post."'target='_self'>上一页</a>";
}else{
$uppage="上一页";
}
if($page<$pagenum){
$downpage="<ahref='".$web."?page=".($page+1)."&".$post."'target='_self'>下一页</a>";
}else{
$downpage="下一页";
}
if($page==$pagenum){
$foot=">>尾页";
}else{
$foot="<ahref='".$web."?page=".$pagenum."&".$post."'target='_self'>>>尾页</a>";
}
$back=<<<eot
共$pagenum页
第$page/$pagenum页$top $uppage $downpage $foot
eot;
}
return$back;
}
}//endclass
?>
下一篇: php获取服务器信息的实现代码
推荐阅读
-
php连接mssql的一些相关经验及注意事项
-
php使用Smarty的相关注意事项及访问变量的几种方式
-
php使用Smarty的相关注意事项及访问变量的几种方式_PHP教程
-
基于HBase Thrift接口的一些使用问题及相关注意事项的详解
-
php 连接 mssql 的一些问题,诚心求人解答
-
php链接局域网mssql的有关问题[原因: 未与信任 SQL Server 连接相关联]
-
php 连接 mssql 的一些有关问题,诚心求人解答
-
php连接mssql的一些相关经验和总结
-
WinXP(32Bit)使用WAMP的经验及PHP连接数据库
-
php 连接 mssql 的一些有关问题,诚心求人解答