如何透過PHP實現Mysql資料庫連接、查詢、記錄集等操作

jacklove
發布: 2018-06-08 10:30:25
原創
1529 人瀏覽過

在PHP網站開發中,經常需要對Mysql資料庫進行操作,大體上需要經過以下幾個步驟:Mysql資料庫連結、Mysql資料庫查詢、Mysql記錄集操作等,如果每次都重複上述操作,不但繁瑣,而且程式碼冗餘度高,對此我整理了部分利用PHP實作Mysql資料庫操作的程式碼,以函數的形式貼出,可依自行需要新增其他功能或整合成Mysql資料庫類別。

Mysql資料庫連結代碼

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;
}
登入後複製

註解:

參數$hostname,$username,$pass,$db_name分別代表Mysql資料庫伺服器位址,使用者名,密碼,以及連線的資料庫名,通常hostname一般都是localhost或127.0.0.1。參數$pconnect預設為0,表示通常情況下是以mysql_connect函數連接Mysql資料庫。

知識點:

mysql_connect與mysql_pconnect的差異:當執行完當前PHP程式後,PHP自動關閉mysql_connect建立的資料庫連接,而mysql_pconnect傳回一個持久穩固的資料庫連接,在一定時間內有下一個連線要求時可以被重複使用,節省了重複連接Mysql資料庫的時間,使得存取速度加快,其適用於同時存取量不大的情況,如並發存取量比較大,則可能會因為Mysql已達到最大連線數, 使之後的請求得不到滿足。

mysql_error函數:傳回上一個Mysql運算產生的文字錯誤訊息。 mysql_errno函數傳回上一個Mysql操作中的錯誤號碼,如果沒有出錯則回傳0。

Mysql資料庫查詢程式碼

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;
}
登入後複製

註解:此函數為Mysql資料庫查詢函數,等於同mysql_query函數的功能,如果出錯則輸出出錯資訊(SQL語句),其實為了防止暴露網站資料庫的結構,正式商用時,最好不要輸出SQL執行語句。

Mysql記錄集操作函數程式碼(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;
}
}
登入後複製

註解:此函數的功能由mysql_fetch_array函數延生而來,在此基礎上我增加了對Mysql資料庫記錄集的讀取功能,並以數組形式傳回所獲得的值。

知識點:

mysql_fetch_array函數是mysql_fetch_row函數的擴充版本。第二個參數 result_type有三個值:MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。預設值是 MYSQL_BOTH。 MYSQL_BOTH:取得一個同時包含關聯和數字索引的陣列。 MYSQL_ASSOC:只得到關聯索引(如同mysql_fetch_assoc()),MYSQL_NUM :得到數字索引(如同 mysql_fetch_row()那樣)。

報錯訊息函數程式碼

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 "";
}
else{
echo "";
}
exit;
}
登入後複製

註解:此函數的功能主要以alert的形式報錯並進行頁面跳轉,是一個通用函數,報錯或跳轉之前其會先將Mysql資料庫連線關閉,用到了mysql_close函數。

呼叫說明:

從上述Mysql資料庫操作的函數程式碼中,我們可以看到$connect變數是一個全域變量,首先將上述幾個函數放入一個文件,例如mysqlconnect .php中,然後在宣告相關變數並賦值,在dbConnect函數宣告後呼叫此Mysql資料庫連接函數,即:

$hostname = "mysqlserveraddr";
$username = "yourusername";
$pass = "youruserpass";
$db_name = "yourdatabase";
$connect = dbConnect($hostname,$username,$pass,$db_name);
登入後複製

  透過上面幾個Mysql資料庫連接、資料庫查詢、資料庫記錄集操作函數程式碼的講解,在PHP網站開發中Mysql資料庫操作的基本函數已包括,根據需要可在此程式碼基礎上改成Mysql資料庫類別或利用PHP添加其他的Mysql資料庫操作函數都是可行的,更多相關推薦請關注php中文網。

相關推薦:

MYSQL查詢時間資料

#如何使用資料庫的方法來保存session

防止SQL注入的五種實作方式

#

以上是如何透過PHP實現Mysql資料庫連接、查詢、記錄集等操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!