问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

mysql 中stmt预处理语句有什么作用

发布网友 发布时间:2022-04-25 16:23

我来回答

4个回答

懂视网 时间:2022-05-01 15:35

预制语句的SQL语法基于三个SQL语句:

        PREPARE stmt_name FROM preparable_stmt;

        EXECUTE stmt_name [USING @var_name [, @var_name] ...];

        {DEALLOCATE | DROP} PREPARE stmt_name;

PREPARE语句用于预备一个语句,并赋予它名称stmt_name,借此在以后引用该语句。

预编译SQL的存活期就是当前的会话,也就是当前的数据库连接。如果连接一断开 ,那就会消失。

例:

mysql> desc tb;

+-------+------------------+------+-----+---------+----------------+

| Field | Type             | Null | Key | Default | Extra          |

+-------+------------------+------+-----+---------+----------------+

| id    | int(10) unsigned | NO   | PRI | NULL    | auto_increment |

| Name  | char(20)         | NO   |     | NULL    |                |

| Age   | tinyint(4)       | NO   |     | NULL    |                |

+-------+------------------+------+-----+---------+----------------+

3 rows in set (0.08 sec)

 

mysql> PREPARE prod FROM "INSERT INTO tb VALUES(?,?,?)";

Query OK, 0 rows affected (0.58 sec)

Statement prepared

 

mysql> PREPARE prod FROM "INSERT INTO tb(name,age) VALUES(?,?)";

Query OK, 0 rows affected (0.00 sec)

Statement prepared

 

mysql> set @p=‘tejevo‘;

Query OK, 0 rows affected (0.06 sec)

 

mysql> set @q=20;

Query OK, 0 rows affected (0.00 sec)

 

mysql> execute prod using @p, @q;

Query OK, 1 row affected (0.05 sec)

 

mysql> select * from tb;

+----+--------+-----+

| id | Name   | Age |

+----+--------+-----+

|  1 | tejevo |  20 |

+----+--------+-----+

1 row in set (0.00 sec)

 

mysql> deallocate prepare prod;

 

说明:from后面跟的就是要进行编译的那个SQL,这个值可以是一个字面的字符串值 ,就像上面,也可以是一个变量。比如:

            set @sql = ‘select * from tb‘;

            prepare pstmt from @sql;  

from后面跟的只能是字面值或者变量这两种情况 ,不能直接跟十六进制的字符串。

被编译的SQL只能是一条单独的语句,不能多条语句一起编译,比如:

             prepare mutisql from ‘select 1;select 2‘;  --- 这是错误的

调用的时候利用using关键字向SQL传递参数 。

              set @value = 1;execute pstmt using @value;  

先声明一个变量来保存参数的值,然后通过后面的using @value来传SQL传递参数 。
注意这里的参数的值只能由变量来传递,不能直接写成execute pstmt using 1; 这是错误的。
多个参数之间用逗号隔开。

 

使用 PREPARE 的几个注意点:
A: PREPARE stmt_name FROM preparable_stmt;   预定义一个语句,并将它赋给 stmt_name ,stmt_name 是不区分大小写的。
B:参数用?代替。即使 preparable_stmt 语句中的 ? 所代表的是一个字符串,你也不需要将 ? 用引号包含起来。
C: 如果新的 PREPARE 语句使用了一个已存在的 stmt_name ,那么原有的将被立即释放!即使这个新的 PREPARE 语句因为错误而不能被正确执行。
D: PREPARE stmt_name 的作用域是当前客户端连接会话可见。
E: 要释放一个预定义语句的资源,可以使用 DEALLOCATE PREPARE 句法。
F: EXECUTE stmt_name 句法中,如果 stmt_name 不存在,将会引发一个错误。 
G: 如果在终止客户端连接会话时,没有显式地调用 DEALLOCATE PREPARE 句法释放资源,服务器端会自己动释放它。
H:可以被预编译的SQL语句的类型也是有限制的,并不是所有的SQL都可以被编译。在预定义语句中,CREATE TABLE, DELETE, DO, INSERT, REPLACE, SELECT, SET, UPDATE, 和大部分的 SHOW 句法被支持。
I:PREPARE 语句不可以用于存储过程(5.0以上可以使用),自定义函数!但从 MySQL 5.0.13 开始,它可以被用于存储过程,仍不支持在函数或触发器中使用!

MySQL预处理语句

标签:

热心网友 时间:2022-05-01 12:43

这就相当于一个方法,已经加载了。只需要你填写一些参数,就能获得相应的结果。这样就大大增加了同样式sql的适用性,性能提高。如果是不同样式的sql,用这种方式反而会降低性能。
如果有不明白请留言。

热心网友 时间:2022-05-01 14:01

预处理效率更高、速度更快、安全性更高

热心网友 时间:2022-05-01 15:36

预处理语句是用preparedstatement
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
为什么来大姨妈胸会胀 少儿学什么舞蹈 青年学什么舞蹈好 成年人学什么舞蹈 福州企业最低工资标准 2013年厦门的底薪是多少 生产要素的需求有哪些性质 生产要素的需求有何特点? 什么是生产要素需求 微观经济学要素需求什么是条件要素需求?它和要素需求有什么不同?_百度... 什么是企业形象宣传片,主要的作用是什么? PHP 使用 Mysqli 的 prepare 语句有什么好处 车辆为外地牌照在合肥能过户吗? 企业形象宣传片的企业形象宣传片综述 请教关于php中使用pdo进行mysql语句的预处理来防止注入的问题_百度知 ... 企业形象宣传片制作 mysql_stmt_prepare的说明 一上,为什么说Mysql预处理可以防止SQL注入 制作 企业宣传视频 合肥市汽车牌照过户怎么办理? mysql prepare疑问 企业宣传视频 打造企业形象 树立企业品牌 央视网管理观察频道 查询优化 为什么要选用预处理语句( mysql 企业形象宣传片拍摄,企业形象片制作公司,企业形象宣传片报价 Mysql API 查询优化 为什么要选用预处理语 合肥车牌能过户给亲人吗? 数据库mysql的查询语句预处理 mysql预处理 语句结果怎么使用prepare 我是滴滴司机在外地想带人回家 安顺滴滴可以带人接单吗? 合肥的牌照在砀山可以直接过户吗? 企业拍摄宣传片好还是广告片好? PHP 使用 Mysqli 的 prepare 语句有什么好处? 合肥的牌照可以过户到江西吗 复古旗有什么,迷信说法 合肥车牌能不能在六安过户 拍摄企业宣传片有什么意义? mysql prepare出错,不明白错在哪里? 求复古新西兰国旗图片 什么是企业宣传片? 合肥户口的车过户到外地需要哪些手续 mysql 字段名做参数 企业形象宣传片和 文化宣传片的区别 请问合肥地区的车牌号怎么过户!(是原车主车牌过户给另一个人) php 使用mysql 的prepare预编译,下面这段代码有防sql注入的功能么?请高... 广州牌照的汽车过户到安徽合肥,汽车在合肥如何办理过户? 美国的国旗长啥样 mysql存储过程中调用Prepare返回值 企业专题片与宣传片.企业形象片有什么区别 父与子车辆过户的话,在合肥现在需要什么样的手