PHP中對資料庫操作的封裝
在動態網面設計中很多都要涉及到對資料庫的操作,但是有時跟據需要而改用其它後台資料庫,就需要大量修改程式。這是一件枯燥、費時而且容易出錯的功作。其實我們可以用PHP中的類別來實現對資料庫操作的封裝,從而使寫出的程式在很小的改動下就可以完成後台資料庫的變更。
現在我們把其封裝在dbfz.inc中,其設計如下:
class dbInterface{ var $dbID=1; //用來決定目前操作的資料庫,當dbID為1代表MySql,當為2代表SQL Server,為3時為ODBC或其它。
var $dbHost; //資料庫所在主機網域名稱
var $dbUsername; //資料庫使用者名稱
var $dbPassword; //使用者密碼
//設定主機、使用者名稱及密碼函數
function setParameter($host,$username,$password){
$this->dbUsername=$username;
$this->dbHost=$host;
$this->dbPassword=$password ;
} //聯結數字庫函數
function dbConnect(){
switch($this->dbID)
{
case 1;
return @mysql_connect( $this->dbHost,$this->dbUsername,$this->dbPassword);
case 2;
//用支援SQL Server的函數
case 3;
//使用支援ODBC的函數
}
}
//關閉數庫函數
function dbClose($dataHandle){
switch($this->dbID)
{
case 1;
mysql_close($dataHandle);
case 2;
//用支援SQL Server的函數
case 3;
//用支援ODBC的函數
}
}
//執行SQL語句函數
function dbQuery($dbName,$sql,$dbHandle){
switch($this->dbID)
{
case 1;
return @mysql_db_query($dbName,$sql,$dbHandle);
case 2;
//用支援SQL Server的函數
case 3;
//用支援ODBC的函數
case 3;
//用支援ODBC的函數
}
}
//擷取SQL回傳值的目前記錄函數
function dbFetchrow($dataHandle,$offset=-1){
switch($this->dbID)
{
case 1;
@mysql_data_seek($dataHandle,$offset);
return @mysql_fetch_row($dataHandle);
case 2;
//用支援 Server的函數
case 3;
//用支援ODBC的函數
}
}
//傳回擷取記錄數函數
function dbNumrows($dataHandle >switch($this->dbID)
{
case 1;
return @mysql_num_rows($dataHandle);
case 2;
//用支援SQL Server的函數
case 3;
//用支援ODBC的函數
}
}
//傳回擷取列數函數
function dbNumcols($dataHandle){
switch($ this->dbID)
{
case 1;
return @mysql_num_fields($dataHandle);
case 2;
//以支援SQL Server的函數
case 3;
//用支援ODBC的函數
}
}
}
現把使用說明如下:
在程式中用dbIntertestface =new dbInterface;
設定參數
test->$dbUsername ;使用者名稱
test->$dbPassword;密碼
test->$dbHost;主機
void setParameter(string host, string username, string password);
資料庫連線:dbhandle test->dbConnect();
回傳值:fasle ,資料庫連線錯誤
>0, 資料庫連線句柄
資料庫關閉:void test->dbClose(dbhandle);
表格運算:int test->dbQuery(string databasename, string sql,dbhandle);執行SQL語句
傳回值: false, SQL執行錯誤
>0, SQL執行正確, 同時指向SQL回傳值,
資料操作:int test->dbFetchrow(dataHandle,int offset);檢索SQL回傳值的目前記錄,成功執行後,指標移向下一筆記錄
int test->dbNumrows(dataHandle); 取得SQL執行後(主要為SELECT語句)所獲得的記錄數
int test->dbNumcols(dataHandle) ; 取得SQL執行後(主要為SELECT語句)所獲得的記錄字段數
現在我們發一個例了講解: 資料庫採用MQSQL:其主機名為"localhost",用戶名為"root"和密碼""。
在mysql有一個testdb資料庫及其中的表table1,表格包括:name和pay兩個欄位
-----
require("testdb.inc"); //裝載dbInterface類別
$test = new dbInterface ;//用類別dbInterface產生一個物件
$test->setParameter("localhost","root","");//設定資料庫參數
$db = $test->dbConnect();/ /連接資料庫
$Query = "SELECT name,pay FROM table ";//設定SQL語句
$temp_result = $test->dbQuery("testdb",$Query,$db);//執行資料主庫操作
echo "
";
$ls_num = $test->dbNumrows($temp_result); //取得查詢結果的記錄數
echo $ls_num;
echo "";
if (ls_num>0 )
{
$ls_col = $test->dbNumcols($db); //取得表格的列數
echo $ls_col;
echo "
";
$cate_result=$test->dbFetchrow($temp_result,0);//取得記錄數的第一行
$hcid=$cate_result[0];// 取得name的值
$hcate=$cate_result[1];//取得pay的值
echo $hcid;
echo "
";
echo $hcate;
}
?>
這就是一個簡單的應用封裝的類別來完成對資料庫的操作。如果要操作其它資料庫只需要修改dbInterface類別中的dbID變數即可.

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

在PHP中,可以利用implode()函数的第一个参数来设置没有分隔符,该函数的第一个参数用于规定数组元素之间放置的内容,默认是空字符串,也可将第一个参数设置为空,语法为“implode(数组)”或者“implode("",数组)”。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

禪工作室 13.0.1
強大的PHP整合開發環境

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Atom編輯器mac版下載
最受歡迎的的開源編輯器