怎么通過(guò)PHP完成Mysql數(shù)據(jù)庫(kù)連接、查詢(xún)、記錄集等設(shè)置
發(fā)表時(shí)間:2023-07-10 來(lái)源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]在PHP網(wǎng)站開(kāi)發(fā)中,經(jīng)常需要對(duì)Mysql數(shù)據(jù)庫(kù)進(jìn)行操作,大體上需要經(jīng)過(guò)以下幾個(gè)步驟:Mysql數(shù)據(jù)庫(kù)鏈接、Mysql數(shù)據(jù)庫(kù)查詢(xún)、Mysql記錄集操作等,如果每次都重復(fù)上述操作,不但繁瑣,而且代碼冗余...
在PHP網(wǎng)站開(kāi)發(fā)中,經(jīng)常需要對(duì)Mysql數(shù)據(jù)庫(kù)進(jìn)行操作,大體上需要經(jīng)過(guò)以下幾個(gè)步驟:Mysql數(shù)據(jù)庫(kù)鏈接、Mysql數(shù)據(jù)庫(kù)查詢(xún)、Mysql記錄集操作等,如果每次都重復(fù)上述操作,不但繁瑣,而且代碼冗余度高,對(duì)此我整理了部分利用PHP實(shí)現(xiàn)Mysql數(shù)據(jù)庫(kù)操作的代碼,以函數(shù)的形式貼出,可根據(jù)自行需要添加其他功能或者整合成Mysql數(shù)據(jù)庫(kù)類(lèi)。
Mysql數(shù)據(jù)庫(kù)鏈接代碼
function dbConnect($hostname,$username,$pass,$db_name,$pconnect = 0)
{
$func = empty($pconnect) ? 'mysql_connect' : 'mysql_pconnect';
if(!$connect) {
$connect = @$func($hostname,$username,$pass) or die("Mysql_Error : ".mysql_error()."
Mysql Error Num : ".mysql_errno()."");
}
@mysql_select_db($db_name, $connect) or die(" Mysql_Error : ".mysql_error()."
Mysql Error Num : ".mysql_errno()."");
return $connect;
}
注釋?zhuān)?/p>
參數(shù)$hostname,$username,$pass,$db_name分別代表Mysql數(shù)據(jù)庫(kù)服務(wù)器地址,用戶名,密碼,以及連接的數(shù)據(jù)庫(kù)名,通常情況下hostname一般都是localhost或者127.0.0.1。參數(shù)$pconnect默認(rèn)為0,表示通常情況下是以mysql_connect函數(shù)連接Mysql數(shù)據(jù)庫(kù)。
知識(shí)點(diǎn):
mysql_connect與mysql_pconnect的區(qū)別:當(dāng)執(zhí)行完當(dāng)前PHP程序后,PHP自動(dòng)關(guān)閉mysql_connect建立的數(shù)據(jù)庫(kù)連接,而mysql_pconnect返回一個(gè)持久穩(wěn)固的數(shù)據(jù)庫(kù)連接,在一定時(shí)間內(nèi)有下一個(gè)連接請(qǐng)求時(shí)可以被復(fù)用,節(jié)省了反復(fù)連接Mysql數(shù)據(jù)庫(kù)的時(shí)間,使得訪問(wèn)速度加快,其適用于并發(fā)訪問(wèn)量不大的情況,如并發(fā)訪問(wèn)量比較大,則可能會(huì)因?yàn)镸ysql已達(dá)到最大連接數(shù), 使之后的請(qǐng)求得不到滿足。
mysql_error函數(shù):返回上一個(gè)Mysql操作產(chǎn)生的文本錯(cuò)誤信息。mysql_errno函數(shù)返回上一個(gè)Mysql操作中的錯(cuò)誤號(hào)碼,如果沒(méi)有出錯(cuò)則返回0。
Mysql數(shù)據(jù)庫(kù)查詢(xún)代碼
function query_error($query)
{
global $connect;
$temp_bar = "
=============================================================================
";
$result = mysql_query($query, $connect) or die("DB ERROR
".$temp_bar." Mysql_Query : ".$query."
Mysql_Error : ".mysql_error()."
Mysql Error Num : ".mysql_errno()."".$temp_bar);
return $result;
}
注釋?zhuān)捍撕瘮?shù)為Mysql數(shù)據(jù)庫(kù)查詢(xún)函數(shù),等于同mysql_query函數(shù)的功能,如果出錯(cuò)則輸出出錯(cuò)信息(SQL語(yǔ)句),其實(shí)為了防止暴露網(wǎng)站數(shù)據(jù)庫(kù)的結(jié)構(gòu),正式商用時(shí),最好不要輸出SQL執(zhí)行語(yǔ)句。
Mysql記錄集操作函數(shù)代碼(mysql_fetch_array)
function fetch_array($result,$result_type = MYSQL_ASSOC,$records = "one")
{
if ($records == "one") {
return @mysql_fetch_array($result,$result_type);
}
else {
for ($i=0;num_rows($result);$i++)
{
$info[$i] = @mysql_fetch_array($result,$result_type);
}
free_result($result);
return $info;
}
}
注釋?zhuān)捍撕瘮?shù)的功能由mysql_fetch_array函數(shù)延生而來(lái),在此基礎(chǔ)上我增加了對(duì)Mysql數(shù)據(jù)庫(kù)記錄集的讀取功能,并以數(shù)組形式返回獲取的值。
知識(shí)點(diǎn):
mysql_fetch_array函數(shù)是mysql_fetch_row函數(shù)的擴(kuò)展版本。第二個(gè)參數(shù) result_type有三個(gè)值:MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。默認(rèn)值是 MYSQL_BOTH。MYSQL_BOTH:得到一個(gè)同時(shí)包含關(guān)聯(lián)和數(shù)字索引的數(shù)組。MYSQL_ASSOC:只得到關(guān)聯(lián)索引(如同mysql_fetch_assoc()那樣),MYSQL_NUM :得到數(shù)字索引(如同 mysql_fetch_row()那樣)。
報(bào)錯(cuò)信息函數(shù)代碼
function error_msg($msg, $url= "")
{
global $connect;
if($connect) {
mysql_close($connect);
}
switch ($url)
{
case "":
$url = "history.go(-1)";
break;
case "close":
$url = "window.close()";
break;
default:
$url = "document.location.href = '$url'";
break;
}
if (!empty($msg)) {
echo "<script language='javascript'>alert('$str');$url;</script>";
}
else{
echo "<script language='javascript'>$url;</script>";
}
exit;
}
注釋?zhuān)捍撕瘮?shù)的功能主要以alert的形式報(bào)錯(cuò)并進(jìn)行頁(yè)面跳轉(zhuǎn),是一個(gè)通用函數(shù),報(bào)錯(cuò)或跳轉(zhuǎn)之前其會(huì)先將Mysql數(shù)據(jù)庫(kù)連接關(guān)閉,用到了mysql_close函數(shù)。
調(diào)用說(shuō)明:
從上述Mysql數(shù)據(jù)庫(kù)操作的函數(shù)代碼中,我們可以看到$connect變量是一個(gè)全局變量,首先將上述幾個(gè)函數(shù)放入一個(gè)文件,如mysqlconnect.php中,然后在聲明相關(guān)變量并賦值,在dbConnect函數(shù)聲明后調(diào)用此Mysql數(shù)據(jù)庫(kù)連接函數(shù),即:
$hostname = "mysqlserveraddr";
$username = "yourusername";
$pass = "youruserpass";
$db_name = "yourdatabase";
$connect = dbConnect($hostname,$username,$pass,$db_name);
通過(guò)上面幾個(gè)Mysql數(shù)據(jù)庫(kù)連接、數(shù)據(jù)庫(kù)查詢(xún)、數(shù)據(jù)庫(kù)記錄集操作函數(shù)代碼的講解,在PHP網(wǎng)站開(kāi)發(fā)中Mysql數(shù)據(jù)庫(kù)操作的基本函數(shù)已包括,根據(jù)需要可在此代碼基礎(chǔ)上改成Mysql數(shù)據(jù)庫(kù)類(lèi)或者利用PHP添加其他的Mysql數(shù)據(jù)庫(kù)操作函數(shù)都是可行的,更多相關(guān)推薦請(qǐng)關(guān)注php中文網(wǎng)。
相關(guān)推薦:
MYSQL查詢(xún)時(shí)間數(shù)據(jù)
如何使用數(shù)據(jù)庫(kù)的方法來(lái)保存session
防止SQL注入的五種實(shí)現(xiàn)方式
以上就是如何通過(guò)PHP實(shí)現(xiàn)Mysql數(shù)據(jù)庫(kù)連接、查詢(xún)、記錄集等操作的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
學(xué)習(xí)教程快速掌握從入門(mén)到精通的SQL知識(shí)。