mssql server 2005连接类
class msDriver{
public $error;
public $querynum=0;
public $link;
public $lastQuery;
public $lastInsert_id=0;
public $error_callback=array('record'); //record,ignore,report,abort
public $error_report_file=ROOT."/webdata/db.error.log";
function __construct($server='',$connectionInfo=array()){
if ($server){
$this->connect($server,$connectionInfo);
}
}
function __destruct(){
!$link && $link= &$this->link;
if ($link) sqlsrv_close( $link );
}
function connect($dbhost='(local)', $connectionInfo=array()){
$this->link=sqlsrv_connect($dbhost,$connectionInfo);
if (!$this->link) $this->halt();
}
/**
*查询过程
*
* @param string $sql
* @param resource $link
* @return resource
*/
function query($sql="",$link=''){
!$link && $link= &$this->link;
);
$this->lastQuery=&$query;
if (!$query) $this->halt();
$reg = "#insert into#";
if(preg_match($reg,$sql)){
$res = sqlsrv_query($link,"select @@IDENTITY as id");
$this->lastInsert_id = sqlsrv_get_field($res,0);
}
return $query;
}
/**
* 返回字段总数
*
* @param resource $result
* @return number
*/
function num_fields($result=''){
if (!$result) $this->halt();
return @sqlsrv_num_fields($result);
}
/**
* 返回字段值
*
* @param resource $result
* @param Int $fieldIndex
* @return value
*/
function result($result='',$fieldIndex=0){
if (!$result) $this->halt();
return sqlsrv_get_field($result,$fieldIndex);
}
/**
* 返回行数组
*
* @param unknown_type $result
* @return unknown
*/
function fetch_array($result,$type=SQLSRV_FETCH_ASSOC){ //SQLSRV_FETCH_NUMERIC,SQLSRV_FETCH_ASSOC,SQLSRV_FETCH_BOTH
!$result && $result=$this->lastQuery;
if (!$result) $this->halt();
);
return is_array($r)?$r:0;
}
/**
* 返回影响的记录数
*
* @param resource $result
* @return number
*/
function affected_rows($result) {
if (!$result) $this->halt();
return sqlsrv_rows_affected($result);
}
function insert_id(){
return $this->lastInsert_id;
}
function freeResult($result){
!$result && $result=$this->lastQuery;
sqlsrv_free_stmt($result);
}
/**
* 错误的处理方式
*
*/
function halt(){
$err=$this->getEroor();
//var_dump($err['']);
if (in_array('record',$this->error_callback)){
$fp=fopen($this->error_report_file,'a+');
if ($fp){
fwrite($fp,"[".date("Y//m/dH:i:s")."](".$err['code'].")".$err['message'].",URL:".$_SERVER["REQUEST_URI"]."?".$_SERVER["QUERY_STRING"]."rn");
fclose($fp);
}
}
if (in_array('report',$this->error_callback)){
echo "
错误:[".date("Y//m/d H:i:s")."](".$err['code'].")".$err['message'];
}
if (in_array('abort',$this->error_callback)){
exit;
}
}
/**
* 返回查询错误
*
* @return array
*/
function getEroor(){
$err=sqlsrv_errors();
//return array('code'=>$err['code'],'message'=>$err['message']);
return is_array($err)?$err[0]:array();
}
}
php mssql server 2005数据库连接类
来源:这里教程网
时间:2026-02-28 05:57:36
作者:
编辑推荐:
- 多款高效sql存储过程分页代码(1/8)02-28
- php mssql server 2005数据库连接类02-28
- mssql server 常用日期函数02-28
- SQL2000和SQL2005冲突的解决方法02-28
- mssql sql语优化实例不使用insert语句(1/2)02-28
- sql like 语法 与sql like 模糊查询02-28
- PHP如何与 MSSQL连接02-28
- mssql server 数据库连接大全02-28
下一篇:
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- Win11 21H2版本停止服务要升级系统吗?
Win11 21H2版本停止服务要升级系统吗?
26-02-28 - SQLServer执行计划成本(续1)
SQLServer执行计划成本(续1)
26-02-28 - 修改电脑、伺服器名称后,SQL Server 的修正作业--补遗篇
修改电脑、伺服器名称后,SQL Server 的修正作业--补遗篇
26-02-28 - 新手必备,教你轻松安装Win10系统!
新手必备,教你轻松安装Win10系统!
26-02-28 - Windows开机黑屏如何重装系统?【图文详解】
Windows开机黑屏如何重装系统?【图文详解】
26-02-28 - 云计算之路-阿里云上:超级奇怪的“黑色10秒钟”
云计算之路-阿里云上:超级奇怪的“黑色10秒钟”
26-02-28 - 解决SYS本地登录或远程登录引起ORA-01031错误方法
解决SYS本地登录或远程登录引起ORA-01031错误方法
26-02-28 - ora-12154:tns:无法解析指定的连接标识符
ora-12154:tns:无法解析指定的连接标识符
26-02-28 - 创建 Oracle 分页存储过程
创建 Oracle 分页存储过程
26-02-28 - NoSQL学习之路(四):创建、读
NoSQL学习之路(四):创建、读
26-02-28
