当前位置 博文首页 > 文章内容

    prepare,理解Mysql prepare预处理语句

    作者:zyd1113wz 栏目:网站相关 时间:2021-03-26 16:57:23

    本站于2023年9月4日。收到“大连君*****咨询有限公司”通知
    说我们IIS7站长博客,有一篇博文用了他们的图片。
    要求我们给他们一张图片6000元。要不然法院告我们

    为避免不必要的麻烦,IIS7站长博客,全站内容图片下架、并积极应诉
    博文内容全部不再显示,请需要相关资讯的站长朋友到必应搜索。谢谢!

    另祝:版权碰瓷诈骗团伙,早日弃暗投明。

    相关新闻:借版权之名、行诈骗之实,周某因犯诈骗罪被判处有期徒刑十一年六个月

    叹!百花齐放的时代,渐行渐远!



         1、Prepare 介绍 

         Prepared Statements很像存储过程,是一种运行在后台的SQL语句集合,我们可以从使用 prepared statements 获得很多好处,无论是性能问题还是安全问题。

         Prepared Statements 可以检查一些你绑定好的变量,这样可以保护你的程序不会受到“SQL注入式”攻击。

         当然,你也可以手动地检查你的这些变量,然而,手动的检查容易出问题,而且很经常会被程序员忘了。

         在性能方面,当一个相同的查询被使用多次的时候,这会为你带来可观的性能优势。你可以给这些Prepared Statements定义一些参数,而MySQL只会解析一次。最新版本的MySQL在传输Prepared Statements是使用二进制形势,所以这会使得网络传输非常有效率。

         2、PREPARE语法

         语法:

         PREPARE statement_name FROM sql_text /*定义*/   

         EXECUTE statement_name [USING variable [,variable...]] /*执行预处理语句*/   

         DEALLOCATE PREPARE statement_name /*删除定义*/   

         示例:

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

         mysql> SET @p='1';   

         mysql> SET @q='2';   

         mysql> EXECUTE prod USING @p,@q;   

         mysql> SET @name='3';   

         mysql> EXECUTE prod USING @p,@name;   

         mysql> DEALLOCATE PREPARE prod;  

         3、PREPARE 特点

         特点如下: 

         (1)PREPARE stmt_name FROM preparable_stmt;预定义一个语句,并将它赋给 stmt_name ,tmt_name 是不区分大小写的。

         (2)即使 preparable_stmt 语句中的 ? 所代表的是一个字符串,你也不需要将 ? 用引号包含起来。 

         (3)如果新的 PREPARE 语句使用了一个已存在的 stmt_name ,那么原有的将被立即释放! 即使这个新的 PREPARE 语句因为错误而不能被正确执行。

         (4)PREPARE stmt_name 的作用域是当前客户端连接会话可见。 

         (5)要释放一个预定义语句的资源,可以使用 DEALLOCATE PREPARE 句法。 

         (6)EXECUTE stmt_name 句法中,如果 stmt_name 不存在,将会引发一个错误。 

         (7)如果在终止客户端连接会话时,没有显式地调用 DEALLOCATE PREPARE 句法释放资源,服务器端会自己动释放它。 

         (8)在预定义语句中,CREATE TABLE, DELETE, DO, INSERT, REPLACE, SELECT, SET, UPDATE, 和大部分的 SHOW 句法被支持。

         (9)PREPARE 语句可以用于存储过程(从版本MySQL 5.0.13以后),不支持在函数中使用

         4、用于存储过程 

         示例:

         5、性能比较

         prepare跟普通的sql语句的性能比较

         执行结果:

         普通mysql运行1000条数据时间为: 0.011621秒

         普通mysql运行10000条数据时间为: 0.07766891秒

         普通mysql运行100000条数据时间为: 0.10834217秒

     

         预查询mysql运行1000条数据时间为: 0.00963211秒

         预查询mysql运行10000条数据时间为: 0.04614592秒

         预查询mysql运行100000条数据时间为: 0.05989885秒

         原文链接:https://blog.csdn.net/qq_42030417/article/details/80372800