|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
PHP原始为Personal Home Page的缩写,已经正式更名为 "PHP: Hypertext Preprocessor"。注意不是“Hypertext Preprocessor”的缩写,这种将名称放到定义中的写法被称作递归缩写。 良多伴侣问我若何用php法式来毗连SQL Server数据库的通用类,其实这个并非很难的,关头是一点点细心,一点点耐烦,用热情去了解
<?
class DB {
var $Host = "192.168.0.199"; // Hostname of our MySQL server
var $Database = "test"; // Logical database name on that server
var $User = "user"; // Database user
var $Password = "password"; // Database user's password
var $Link_ID = 0; // Result of mssql_connect()
var $Query_ID = 0; // Result of most recent mssql_query()
var $Row = 0; // Current row number
var $Errno = 0; // Error state of query
var $Error = "";
var $AffNum=0;
/**************************************
*打印毛病办法:显示页面处置的毛病信息。
****************************************/
function Halt($msg) {
printf("</td></tr></table><b>Database error:</b> %s<br>\n", $msg);
printf("<b>mssql Error</b>: %s (%s)<br>\n",
$this->Errno,
$this->Error);
die("Session halted.");
}
/**************************************
*毗连数据库,而且选择默许的数据库
**************************************/
function Connect() {
if ( 0 == $this->Link_ID ) {
$this->Link_ID=mssql_connect($this->Host,$this->User,$this->Password) or die("Couldn't connect to SQL Server on
$servername");
Database,$this->Link_ID">$db=@mssql_select_db($this->Database,$this->Link_ID);
if (!$this->Link_ID) {
$this->Halt("Link-ID == false, mssql_connect failed");
}
}
}
/****************************************
*封闭数据库,假如数据库毗连已翻开则封闭它
*请在挪用Connect()并处置后利用Close()
****************************************/
function Close() {
if (0 != $this->Link_ID){
mssql_close();
}
}
/*************************************************
*输出sql语句,有select,update,insert,delete
*包含存储进程也能够经由过程这个办法来挪用。
*************************************************/
function Query($Query_String) {
$this->Connect();
$this->Query_ID = mssql_query($Query_String);
$this->Row = 0;
if (!$this->Query_ID) {
$msg=mssql_get_last_message();
if($msg==null || $msg=="")
{
$this->AffNum=1;
return 1;
}
if(strtolower(substr($Query_String,0,6))!="select"){
$this->AffNum=1;
return 1;
}
$this->Errno = 1;
$this->Error = "General Error (The mssql interface cannot return detailed error messages)(".$msg.").";
$this->halt("Invalid SQL: ".$Query_String);
}
return $this->Query_ID;
}
/*******************************************************
*把查询数据库的指针移到下一笔记录
*******************************************************/
function NextRecord() {
$this->Record = array();
mssql_next_result($this->Query_ID);
$this->Record=mssql_fetch_array($this->Query_ID);
$result=$this->Record;
if(!is_array($result)) return $this->Record;
foreach($result as $key => $value){
$keylower=strtolower($key);
if($keylower!=$key) $this->Record[$keylower]=$value;
}
return $this->Record;
}
/********************************************************
*从头定位查询数据库的指针
********************************************************/
function Seek($pos) {
if($pos<=0) return;
if(eregi("[0-9]",$pos)) mssql_data_seek($this->Query_ID,$pos);
}
/********************************************************
*获得查询数据库失掉的总行数
********************************************************/
function NumRows() {
if($this->Query_ID) $num_rows=mssql_num_rows($this->Query_ID);
else $num_rows=$this->AffNum;
return $num_rows;
}
/*******************************************************
*字段数
*******************************************************/
function NumFields() {
return count($this->Record)/2;
}
/*******************************
*该字段的值
*******************************/
function FieldValue($Field_Name){
return $this->Record[$Field_Name];
}
/******************************
*update,insert,delete影响的行数
******************************/
function AffectedRows() {
if($this->Query_ID) return mssql_num_rows($this->Query_ID);
else{
return $this->AffNum;
}
}
?>
以下是利用示例:
<?
//机关新的DB类
$DBConn=new DB;
//写入sql查询语句
$SqlStr="select * from test";
$DBConn->Query($SqlStr);
//轮回输入查询失掉的了局
while($Row=$DBConn->NextRecord()){
echo $Row[testid];
}
//封闭数据库毗连
$DBConn->Close();
?>在我开始学习PHP以前,我从未想过要做软件工程,即便是在去听过华育国际的关于软件工程的美好前景后,因为我一直都没有想过要与代码打交道,而是想学好所学专业,做个网络工程师或者是网络安全人员。 |
|