详细介绍:
由于工作的原因,需要对SQL SERVER数据库进行操作,根据以前使用的MySQL数据库操作类改写成现在这个对SQL SERVER进行操作的PHP类,可以执行连接数据库,执行SQL语句,查询数据,获得最后一次插入操作的ID号等功能!
/****************************************************************************
db_mssql_class.php - description
-------------------
begin : 2002 4 2
$Id: db_mssql_class.php,v 1.1 2002/04/03 09:25:33 Simon.Qiu Exp $
/****************************************************************************/
class DB_Handle{
var $ClassName = "DB_Handle";
var $Server;
var $UserName;
var $Password;
var $Database;
var $LinkID=0;
var $QueryResult="";
var $LastInsertID = "";
/* private ignore=>ignore the error and continue, halt=>report the error and halt, report=>report the error and continue */
var $Halt_On_Error = "report";
var $Error = "";
var $ErrNo = 0;
/**public
* remark: This is the db_mysql_class's structure
* function: Set the server,username,password,database variable.
*/
function DB_Handle($server="",$username="",$password="",$database=""){
$this->Server = $server;
$this->UserName = $username;
$this->Password = $password;
$this->Database = $database;
}
/**public
* function: Connect database and select database
* success: retun 1
* failed: return 0
*/
function connect(){
$this->LinkID = @mssql_pconnect($this->Server,$this->UserName,$this->Password);
if(!$this->LinkID){
$this->halt("mssql_pconnect($this->Server,$this->UserName,$this->Password): Failed");
return 0;
}
if(!@mssql_select_db($this->Database)){
$this->halt("mssql_select_db($this->Database) Failed.");
return 0;
}
return 1;
}
/**public
* function: Check the database, if exist then select
* exist: return 1
* not exist: return 0
*/
function selectDatabase(){
if(@mssql_select_db($this->Database))
return 1;
else
return 0;
}
/**public
* 関数: SQL 命令を実行します
* 成功: SQL 結果を返します。
* 失敗: 0 を返します。
*/
function execQuery($sql=""){
if($this->LinkID == 0){
$this->halt("SQL の実行に失敗しました: Hava ではありません有効なデータベース接続。");
return 0;
}
ob_start();
$this->QueryResult = mssql_query($sql,$this->LinkID);
$error = ob_get_contents();
ob_end_clean ();
if($error){
$this->halt("SQL の実行: mssql_query($sql,$this->LinkID) が失敗しました。");
return 0;
}
$reg = "#insert into#";
if(preg_match($reg,$sql)){
$sql = "ID として @@IDENTITY を選択";
$res = mssql_query($sql,$this->LinkID);
$this->LastInsertID = mssql_result($res,0,id);
}
return $this->QueryResult;
}
/**public
* 関数: クエリ結果の行番号を取得します
* 成功: Result の行を返します
* 失敗: 0 を返します
*/
function getTotalRowNum($result=" "){
if($result != "") $this->QueryResult = $result;
$row = @mssql_num_rows($this->QueryResult);
if($row >= 0) return $ row;
$this->halt("結果の行の取得に失敗しました: 結果 $result が無効です。");
return 0;
}
/**public
* 関数: 最後の挿入レコードの id を取得します
* 成功: id を返す
* 失敗: 0 を返す
*/
function lastInsertID(){
return $this->LastInsertID;
}
/**public
* 関数: フィールドの値を取得する
* 成功: フィールドの値を返す
* 失敗: 0 を返す
*/
function getField($result="",$row=0,$field=0){
if($result != "") $this->QueryResult = $result;
$fieldvalue = @mssql_result($this->QueryResult,$row,$field);
if($fieldvalue != "") return $fieldvalue;
$ this->halt("Get field: mssql_result($this->QueryResult,$row,$field) failed.");
return 0;
//ここにはエラー ハンドルがあるはずです
}
/* *public
* 関数: 次のレコードを取得します
* 成功: レコードの値の配列を返します
* 失敗: 0 を返します
*/
function nextRecord($result=""){
if($result != "") $this->QueryResult = $result;
$record = @mssql_fetch_array($this->QueryResult );
if(is_array($record)) return $record;
//$this->halt("次のレコードの取得に失敗しました: 結果 $result が無効です。");
return 0;
}
/**public
* 関数: クエリ結果を解放します
* 成功した場合は 1 を返します
* 失敗した場合: 0 を返す
*/
function freeResult($result=""){
if($result != "") $this->QueryResult = $result;
return @mssql_free_result($this-> QueryResult);
}
/**public
* 関数: Halt_On_Error の状態を設定します
* 成功: 1 を返します
* 失敗: 0 を返します
*/
function setHaltOnError($state="ignore"){
if(!($state == "ignore" || $state == "レポート" || $state == "halt")){
$this->halt("Halt_On_Error の設定失敗: 状態値 $state がありません");
return 0;
}
$this->Halt_On_Error = $state;
return 1;
}
/**public
* 関数: Halt_On_Error の状態を取得する
*/
function getHaltOnError(){
return $this->Halt_On_Error;
}
/**public
* 関数: クラス名を取得します
*/
function toString(){
return $this->ClassName;
}
/**private
* 関数: エラーハンドル
*/
function halt($msg){
$this-> Error = @mysql_error($this->LinkID);
$this->ErrNo = @mysql_errno($this->LinkID);
if ($this->Halt_On_Error == "ignore") return;
$this->makeMsg($msg);
if ($this->Halt_On_Error == "停止") die("セッションが停止しました");
}
/**private
* 関数: エラー情報の作成と印刷
*/
function makeMsg($msg){
printf("データベース エラー:gt; %s
n", $msg);
printf("< b>MySQL エラー: %s (%s)
n",$this->ErrNo,$this->Error);
}
}
?>