MySQL?Prepared?Statement?預(yù)處理的操作方法
預(yù)處理語(yǔ)句(Prepared Statement) 是一種在數(shù)據(jù)庫(kù)管理系統(tǒng)中使用的編程概念,用于執(zhí)行對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作的 SQL 語(yǔ)句。
使用預(yù)處理語(yǔ)句的具體方式和語(yǔ)法依賴于所用的編程語(yǔ)言和數(shù)據(jù)庫(kù)管理系統(tǒng)。常見(jiàn)的編程語(yǔ)言如 Java、PHP、Python 和 C# 都提供了對(duì)預(yù)處理語(yǔ)句的支持。
在MySQL版本4.1之前,查詢以文本格式發(fā)送到MySQL服務(wù)器。反過(guò)來(lái),MySQL使用 文本協(xié)議(text protocol) 將數(shù)據(jù)返回給客戶端。MySQL必須完全解析查詢并將結(jié)果集轉(zhuǎn)換為字符串,然后再將其返回給客戶端。
文本協(xié)議具有嚴(yán)重的性能影響。為解決此問(wèn)題,自4.1版本后,MySQL添加了一項(xiàng)新特性—— prepared statement
prepared statement
利用 client/server binary protocol ,它將包含占位符(?)的查詢語(yǔ)句發(fā)送到MySQL服務(wù)器:
SELECT column_list FROM products WHERE productcode = ?;
當(dāng) MySQL 使用不同的 productcode
值 執(zhí)行此查詢時(shí),它不必完全解析查詢。這有助于MySQL更快地執(zhí)行查詢,提升程序的性能,特別是當(dāng)MySQL多次執(zhí)行相同的查詢時(shí)。
由于預(yù)處理語(yǔ)句使用占位符(?
),這有助于避免許多SQL注入的變體,使應(yīng)用程序更安全。
預(yù)處理語(yǔ)句的基本思想是將 SQL 語(yǔ)句和參數(shù)分離開(kāi)來(lái)。在執(zhí)行之前,數(shù)據(jù)庫(kù)管理系統(tǒng)會(huì)先解析并編譯預(yù)處理語(yǔ)句,然后將其保存在預(yù)處理語(yǔ)句的執(zhí)行計(jì)劃中。
當(dāng)應(yīng)用程序需要執(zhí)行相同或類似的 SQL 語(yǔ)句時(shí),只需要對(duì)參數(shù)進(jìn)行修改,而不必重新解析和編譯整個(gè) SQL 語(yǔ)句,從而提高執(zhí)行效率。
使用步驟
使用預(yù)處理語(yǔ)句通常需要以下幾個(gè)步驟:
- 準(zhǔn)備預(yù)處理語(yǔ)句:應(yīng)用程序先將 SQL 語(yǔ)句發(fā)送給數(shù)據(jù)庫(kù)管理系統(tǒng),并告知數(shù)據(jù)庫(kù)要使用預(yù)處理語(yǔ)句的方式進(jìn)行處理。數(shù)據(jù)庫(kù)會(huì)進(jìn)行語(yǔ)法分析和執(zhí)行計(jì)劃的生成,生成一個(gè)可執(zhí)行的預(yù)處理語(yǔ)句對(duì)象。
- 綁定參數(shù):應(yīng)用程序?qū)⒁獔?zhí)行的 SQL 語(yǔ)句中的參數(shù)值綁定到預(yù)處理語(yǔ)句中。這樣可以防止 SQL 注入攻擊,并且可以使數(shù)據(jù)庫(kù)系統(tǒng)充分利用參數(shù)值進(jìn)行查詢優(yōu)化。
- 執(zhí)行預(yù)處理語(yǔ)句:應(yīng)用程序?qū)⒔壎藚?shù)的預(yù)處理語(yǔ)句發(fā)送給數(shù)據(jù)庫(kù)進(jìn)行執(zhí)行。數(shù)據(jù)庫(kù)會(huì)根據(jù)預(yù)處理語(yǔ)句中的執(zhí)行計(jì)劃執(zhí)行相應(yīng)的操作,并返回結(jié)果給應(yīng)用程序。
用法
使用 預(yù)處理語(yǔ)句 需要如下三個(gè)語(yǔ)句:
PREPARE
:為執(zhí)行準(zhǔn)備一條語(yǔ)句EXECUTE
:執(zhí)行PREPARE語(yǔ)句準(zhǔn)備好的語(yǔ)句DEALLOCATE PREPARE
:發(fā)布準(zhǔn)備好的聲明
-- 示例 '''step 1''' PREPARE stmt1 FROM 'SELECT productCode, productName FROM products WHERE productCode = ?'; '''step 2 聲明一個(gè)變量 pc,代表productcode并為其賦值''' SET @pc = 'S10_1678'; '''step 3 EXECUTE''' EXECUTE stmt1 USING @pc; '''step 4 為變量 pc 分配另一個(gè)product code''' SET @pc = 'S12_1099'; '''step 5 EXECUTE with the new product code''' EXECUTE stmt1 USING @pc; '''step 6 release the prepared statement''' DEALLOCATE PREPARE stmt1;
優(yōu)點(diǎn)
- 提高性能:預(yù)處理語(yǔ)句的執(zhí)行計(jì)劃可以被多次重復(fù)使用,避免了重復(fù)解析和編譯 SQL 語(yǔ)句的開(kāi)銷,提高了執(zhí)行效率。
- 預(yù)防 SQL 注入攻擊:通過(guò)參數(shù)綁定,預(yù)處理語(yǔ)句可以防止惡意用戶通過(guò)輸入特殊字符來(lái)修改 SQL 邏輯,提升了應(yīng)用程序的安全性。
- 方便維護(hù):將 SQL 邏輯和參數(shù)分開(kāi),使代碼清晰易讀,易于維護(hù)和修改。
到此這篇關(guān)于MySQL Prepared Statement 預(yù)處理 的文章就介紹到這了,更多相關(guān)MySQL Prepared Statement 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL 將文件導(dǎo)入數(shù)據(jù)庫(kù)(load data Statement)
- MySQL?如何將查詢結(jié)果導(dǎo)出到文件(select?…?into?Statement)
- MySQL?binlog格式之Row和Statement語(yǔ)句詳解
- The MySQL server is running with the --read-only option so it cannot execute this statement
- MySQL:Unsafe statement written to the binary log using statement format since BINLOG_FORMAT = STATEM
- 詳解JSP中的語(yǔ)句對(duì)象Statement操作MySQL的使用實(shí)例
- 解決mysql報(bào)錯(cuò)You must reset your password using ALTER USER statement before executing this statement問(wèn)題
相關(guān)文章
解決mysql.server?start執(zhí)行報(bào)錯(cuò)ERROR!The?server?quit?without?u
這篇文章主要介紹了解決mysql.server?start執(zhí)行報(bào)錯(cuò)ERROR!The?server?quit?without?updating?PID?file問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09MySQL8.0.27安裝過(guò)程中卡在Initializing?Database中并報(bào)錯(cuò)的解決
本文主要介紹了MySQL8.0.27安裝過(guò)程中卡在Initializing?Database中并報(bào)錯(cuò)的解決,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05mysql創(chuàng)建外鍵報(bào)錯(cuò)的原因及解決(can't?not?create?table)
這篇文章主要介紹了mysql創(chuàng)建外鍵報(bào)錯(cuò)的原因及解決方案(can't?not?create?table),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09修改mysql默認(rèn)字符集的兩種方法詳細(xì)解析
下面小編就為大家介紹兩種修改mysql默認(rèn)字符集的方法。需要的朋友可以過(guò)來(lái)參考下2013-08-08SQLyog的下載、安裝、破解、配置教程(MySQL可視化工具安裝)
SQLyog是一款MySQL可視化工具,他可以將部分SQL操作通過(guò)圖形化界面操作來(lái)完成,方便開(kāi)發(fā)者更好的進(jìn)行開(kāi)發(fā)及數(shù)據(jù)庫(kù)設(shè)計(jì),這篇文章主要介紹了SQLyog的下載、安裝、破解、配置(MySQL可視化工具安裝),需要的朋友可以參考下2022-09-09