国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - MySQL中預處理語句prepare、execute與deallocate的使用教程

MySQL中預處理語句prepare、execute與deallocate的使用教程

2020-08-12 16:32神諭丶 Mysql

這篇文章主要介紹了MySQL中預處理語句prepare、execute與deallocate的使用教程,文中通過示例代碼介紹的非常詳細,對大家學習或者使用mysql具有一定的參考學習價值,需要的朋友們下面跟著小編一起來學習學習吧。

前言

MySQL官方將prepareexecute、deallocate統稱為PREPARE STATEMENT,我習慣稱其為【預處理語句】,其用法十分簡單,下面話不多說,來一起看看詳細的介紹吧。

示例代碼

?
1
2
3
4
5
6
PREPARE stmt_name FROM preparable_stmt
 
EXECUTE stmt_name
 [USING @var_name [, @var_name] ...] -
 
{DEALLOCATE | DROP} PREPARE stmt_name

舉個栗子:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
mysql> PREPARE pr1 FROM 'SELECT ?+?';
Query OK, 0 rows affected (0.01 sec)
Statement prepared
 
mysql> SET @a=1, @b=10 ;
Query OK, 0 rows affected (0.00 sec)
 
mysql> EXECUTE pr1 USING @a, @b;
+------+
| ?+? |
+------+
| 11 |
+------+
1 row in set (0.00 sec)
 
mysql> EXECUTE pr1 USING 1, 2; -- 只能使用用戶變量傳遞。
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the
right syntax to use near '1, 2' at line 1
 
mysql> DEALLOCATE PREPARE pr1;
Query OK, 0 rows affected (0.00 sec)

使用PAREPARE STATEMENT可以減少每次執行SQL的語法分析,比如用于執行帶有WHERE條件的SELECT和DELETE,或者UPDATE,或者INSERT,只需要每次修改變量值即可。

同樣可以防止SQL注入,參數值可以包含轉義符和定界符。

適用在應用程序中,或者SQL腳本中均可。

更多用法:

同樣PREPARE ... FROM可以直接接用戶變量:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
mysql> CREATE TABLE a (a int);
Query OK, 0 rows affected (0.26 sec)
 
mysql> INSERT INTO a SELECT 1;
Query OK, 1 row affected (0.04 sec)
Records: 1 Duplicates: 0 Warnings: 0
 
mysql> INSERT INTO a SELECT 2;
Query OK, 1 row affected (0.04 sec)
Records: 1 Duplicates: 0 Warnings: 0
 
mysql> INSERT INTO a SELECT 3;
Query OK, 1 row affected (0.04 sec)
Records: 1 Duplicates: 0 Warnings: 0
 
mysql> SET @select_test = CONCAT('SELECT * FROM ', @table_name);
Query OK, 0 rows affected (0.00 sec)
 
mysql> SET @table_name = 'a';
Query OK, 0 rows affected (0.00 sec)
 
mysql> PREPARE pr2 FROM @select_test;
Query OK, 0 rows affected (0.00 sec)
Statement prepared
 
mysql> EXECUTE pr2 ;
+------+
| a |
+------+
| 1 |
| 2 |
| 3 |
+------+
3 rows in set (0.00 sec)
 
mysql> DROP PREPARE pr2; -- 此處DROP可以替代DEALLOCATE
Query OK, 0 rows affected (0.00 sec)

每一次執行完EXECUTE時,養成好習慣,須執行DEALLOCATE PREPARE … 語句,這樣可以釋放執行中使用的所有數據庫資源(如游標)。

不僅如此,如果一個session的預處理語句過多,可能會達到max_prepared_stmt_count的上限值。

預處理語句只能在創建者的會話中可以使用,其他會話是無法使用的。

而且在任意方式(正常或非正常)退出會話時,之前定義好的預處理語句將不復存在。

如果在存儲過程中使用,如果不在過程中DEALLOCATE掉,在存儲過程結束之后,該預處理語句仍然會有效。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:http://blog.itpub.net/29773961/viewspace-1852824/

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 色综合天天综合网国产成人网 | 婷婷成人基地 | 亚洲欧美日韩精品 | 欧美一级片在线 | 欧美视频一二三区 | 一区二区国产精品 | 一区二区三区在线免费播放 | 天天综合久久 | 久久久网站 | 国产成人av一区二区三区 | 国产在线不卡 | 国产成人一区 | 免费日韩精品 | 国产精品一区二区不卡 | 在线观看国产精品一区 | 亚洲视频中文字幕 | 日韩午夜在线视频 | 欧美亚洲综合久久 | 久久亚 | 日狠狠 | 快色视频在线观看 | 自拍视频网站 | 亚洲国产精品自拍视频 | 午夜精品视频在线观看 | 午夜999| 久久国产精品免费一区二区三区 | 午夜操操操 | 91精品国产高清一区二区三区 | 国产成人黄色片 | 久久久久久毛片免费播放 | 黄色av网站在线观看 | 一区二区三区高清不卡 | www.亚洲成人| 激情欧美一区二区三区中文字幕 | 一级在线看| 亚洲精品久 | 在线观看的av | 亚洲五月婷婷 | 久久av网| 午夜免费在线 | 久久久久久99 |