在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 "<script language='javascript'>alert('$str');$url;</script>"; } else{ echo "<script language='javascript'>$url;</script>"; } 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中文網。
相關推薦:
#以上是如何透過PHP實現Mysql資料庫連接、查詢、記錄集等操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

mysqldiffersfromothersqldialectsinsyntaxforlimit,自動啟動,弦樂範圍,子征服和表面上分析。 1)MySqluessLipslimit,whilesqlserverusestopopandoraclesrontersrontsrontsrontsronnum.2)

MySQL分區能提升性能和簡化維護。 1)通過按特定標準(如日期範圍)將大表分成小塊,2)物理上將數據分成獨立文件,3)查詢時MySQL可專注於相關分區,4)查詢優化器可跳過不相關分區,5)選擇合適的分區策略並定期維護是關鍵。

在MySQL中,如何授予和撤銷權限? 1.使用GRANT語句授予權限,如GRANTALLPRIVILEGESONdatabase_name.TO'username'@'host';2.使用REVOKE語句撤銷權限,如REVOKEALLPRIVILEGESONdatabase_name.FROM'username'@'host',確保及時溝通權限變更。

InnoDB適合需要事務支持和高並發性的應用,MyISAM適合讀多寫少的應用。 1.InnoDB支持事務和行級鎖,適用於電商和銀行系統。 2.MyISAM提供快速讀取和索引,適合博客和內容管理系統。

MySQL中有四種主要的JOIN類型:INNERJOIN、LEFTJOIN、RIGHTJOIN和FULLOUTERJOIN。 1.INNERJOIN返回兩個表中符合JOIN條件的所有行。 2.LEFTJOIN返回左表中的所有行,即使右表中沒有匹配的行。 3.RIGHTJOIN與LEFTJOIN相反,返回右表中的所有行。 4.FULLOUTERJOIN返回兩個表中所有符合或不符合JOIN條件的行。

mysqloffersvariousStorageengines,每個suitedfordferentusecases:1)InnodBisidealForapplicationsNeedingingAcidComplianCeanDhighConcurncurnency,supportingtransactionsancions and foreignkeys.2)myisamisbestforread-Heavy-Heavywyworks,lackingtransactionsactionsacupport.3)記憶

MySQL中常見的安全漏洞包括SQL注入、弱密碼、權限配置不當和未更新的軟件。 1.SQL注入可以通過使用預處理語句防止。 2.弱密碼可以通過強制使用強密碼策略避免。 3.權限配置不當可以通過定期審查和調整用戶權限解決。 4.未更新的軟件可以通過定期檢查和更新MySQL版本來修補。

在MySQL中識別慢查詢可以通過啟用慢查詢日誌並設置閾值來實現。 1.啟用慢查詢日誌並設置閾值。 2.查看和分析慢查詢日誌文件,使用工具如mysqldumpslow或pt-query-digest進行深入分析。 3.優化慢查詢可以通過索引優化、查詢重寫和避免使用SELECT*來實現。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

WebStorm Mac版
好用的JavaScript開發工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具