MySQL prepare语法:
PREPARE statement_name FROM preparable_SQL_statement; /*定义*/
EXECUTE statement_name [USING @var_name [, @var_name] ...]; /*执行预处理语句*/
{DEALLOCATE | DROP} PREPARE statement_name /*删除定义*/ ;
PREPARE语句用于预备一个语句,并指定名称statement_name,以后引用该语句。语句名称对大小写不敏感。preparable_stmt可以是一个文字字符串,也可以是一个包含了语句文本的用户变量。该文本必须表现为一个单一的SQL语句,而不是多个语句。在这语句里,‘?'字符可以被用于标识参数,当执行时,以指示数据值绑定到查询后。‘?'字符不应加引号,即使你想要把它们与字符串值结合在一起。参数标记只能用于数据值应该出现的地方,而不是SQL关键字,标识符,等等。
如果预语句已经存在,则在新的预语句被定义前,它会被隐含地删掉。
每次都看别人的,今天我自己写下来,以后就不用看别人的了
语法
PREPARE statement_name FROM sql_text /*定义*/
EXECUTE statement_name [USING variable [,variable...]] /*执行预处理语句*/
DEALLOCATE PREPARE statement_name /*删除定义*/
例
复制代码 代码如下:
mysql> PREPARE prod FROM "INSERT INTO examlple 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;
例如:
mysql> prepare optimize_tables from "optimize table temp";
Query OK, 0 rows affected (0.00 sec)
Statement prepared
mysql> execute optimize_tables;
+-----------+----------+----------+----------+
| Table | Op | Msg_type | Msg_text |
+-----------+----------+----------+----------+
| test.temp | optimize | status | OK |
+-----------+----------+----------+----------+
1 row in set (0.37 sec)
mysql> deallocate prepare optimize_tables;
Query OK, 0 rows affected (0.00 sec)
--------------------------------------------------------------------------
mysql> prepare md5sum from 'select md5(?) AS md5sum';
Query OK, 0 rows affected (0.00 sec)
Statement prepared
mysql> set @a=111;
Query OK, 0 rows affected (0.00 sec)
mysql> set @b=222;
Query OK, 0 rows affected (0.00 sec)
mysql> execute md5sum using @a;
+----------------------------------+
| md5sum |
+----------------------------------+
| 698d51a19d8a121ce581499d7b701668 |
+----------------------------------+
1 row in set (0.00 sec)
mysql> execute md5sum using @b;
+----------------------------------+
| md5sum |
+----------------------------------+
| bcbe3365e6ac95ea2c0343a2395834dd |
+----------------------------------+
1 row in set (0.00 sec)
mysql> drop prepare md5sum;
Query OK, 0 rows affected (0.00 sec)
--------------------------------------------------------------------------------------
mysql> prepare update_table from "update users set password=password('aaa') where username='a'";
Query OK, 0 rows affected (0.00 sec)
Statement prepared
mysql> execute update_table;
Query OK, 0 rows affected (0.00 sec)
Rows matched: 1 Changed: 0 Warnings: 0
mysql> deallocate prepare update_table;
Query OK, 0 rows affected (0.00 sec)
从MySQL 5.0 开始,支持了一个全新的SQL句法:
PREPARE stmt_name FROM preparable_stmt;
EXECUTE stmt_name [USING @var_name [, @var_name] ...];
{DEALLOCATE | DROP} PREPARE stmt_name;
通过它,我们就可以实现类似 MS SQL 的 sp_executesql 执行动态SQL语句!
同时也可以防止注入式攻击!
为了有一个感性的认识,
下面先给几个小例子:
mysql> PREPARE stmt1 FROM 'SELECT SQRT(POW(?,2) + POW(?,2)) AS hypotenuse';
mysql> SET @a = 3;
mysql> SET @b = 4;
mysql> EXECUTE stmt1 USING @a, @b;
+------------+
| hypotenuse |
+------------+
| 5 |
+------------+
mysql> DEALLOCATE PREPARE stmt1;
mysql> SET @s = 'SELECT SQRT(POW(?,2) + POW(?,2)) AS hypotenuse';
mysql> PREPARE stmt2 FROM @s;
mysql> SET @a = 6;
mysql> SET @b = 8;
mysql> EXECUTE stmt2 USING @a, @b;
+------------+
| hypotenuse |
+------------+
| 10 |
+------------+
mysql> DEALLOCATE PREPARE stmt2;
如果你的MySQL 版本是 5.0.7 或者更高的,你还可以在 LIMIT 子句中使用它,示例如下:mysql> SET @a=1;mysql> PREPARE STMT FROM "SELECT * FROM tbl LIMIT ?"; mysql> EXECUTE STMT USING @a;
mysql> SET @skip=1; SET @numrows=5; phperz.com
mysql> PREPARE STMT FROM "SELECT * FROM tbl LIMIT ?, ?";
mysql> EXECUTE STMT USING @skip, @numrows; 使用 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: 在预定义语句中,CREATE TABLE, DELETE, DO, INSERT, REPLACE, SELECT, SET, UPDATE, 和大部分的 SHOW 句法被支持。
G: PREPARE 语句不可以用于存储过程,自定义函数!但从 MySQL 5.0.13 开始,它可以被用于存储过程,仍不支持在函数中使用! 下面给个示例: CREATE PROCEDURE `p1`(IN id INT UNSIGNED,IN name VARCHAR(11))BEGIN lable_exit: BEGIN SET @SqlCmd = 'SELECT * FROM tA '; IF id IS NOT NULL THEN SET @SqlCmd = CONCAT(@SqlCmd , 'WHERE id=?'); PREPARE stmt FROM @SqlCmd; SET @a = id; EXECUTE stmt USING @a; LEAVE lable_exit; END IF; IF name IS NOT NULL THEN SET @SqlCmd = CONCAT(@SqlCmd , 'WHERE name LIKE ?'); PREPARE stmt FROM @SqlCmd; SET @a = CONCAT(name, '%'); EXECUTE stmt USING @a; LEAVE lable_exit; END IF; END lable_exit;END; CALL `p1`(1,NULL);CALL `p1`(NULL,'QQ');DROP PROCEDURE `p1`;
相关推荐:
ChatGDP人工智能:未来科技赋能企业与个人的智能变革,如何用AI绘制人体
ChatGPTWindows版本:让AI助手成为你的工作与生活得力助手,Ai相减变形
seo经理做什么的,seo经理招聘 ,盲人ai眼镜
什么是seo的豆子,何为seo ,ai圆复制
ChatGPT不能访问,我的学术水平直线下降,泰州大数据ai艾灸价格
ChatGPT无法加载?检查您的网络设置并尝试重启,轻松解决连接问题!,ai制作艺术字
AI免费生成文本,内容创作新篇章
SEO站在未来之巅,助力网站在激烈竞争中脱颖而出,推荐网站优化欢迎咨询
用AI写文章,释放你的创作潜力!
seo算是什么营销方式,seo是网络营销吗 ,ai318
SEO检测,让网站排名飞升的秘密武器,高端快消食品营销推广
什么是seo技术,什么是seo及seo的作用 ,AI倒放仓鼠
SEO优化关键技巧:提升网站排名的实战攻略,科大讯飞ai论文写作软件
用AI写文章查重率高吗?揭秘AI写作与查重检测的关系
SEO目的:如何通过精准优化提高网站流量与转化率,百度推广网站关键词
SEO合同:确保您网站优化成功的关键保障,微博营销推广规则最新
seo网络推广要做什么,seo 网络推广 ,ai少女喝药
一秒采集:提升效率、创造价值的秘密武器,苏州网站整站优化
什么是seo模型,seo模块总结 ,ai技术授课
SEO走动:提升网站流量的关键一步,SEO数据监控宝宝推荐
seo网站是什么东西,seo网站是什么东西啊 ,ai锯齿消失
ChatGPT无法使用?了解原因及解决方法,轻松恢复智能对话体验!,ai满版图案
打破创作边界,无限可能无限制生成文章的AI
SEO攻略:搜索引擎优化,快速提升网站排名,网站推广网站优化费用
优化型网站:提升企业竞争力的必备利器,重庆网站推广工作如何
优化网站的秘诀:提高网站速度与用户体验,助力业务腾飞,旅游网站建设步骤
SEO范例:如何通过优化提升网站流量,获取更多商机,广州抖音seo搜索广告
seo用什么手法,seo方式 ,ai绘画飞翔
AI提炼主要内容:如何让信息更精准、高效、易懂,女军人ai
SEO招标:如何通过专业SEO服务助力企业脱颖而出,牡丹江关键词排名怎么样
为什么seo推广那么多,seo推广难吗 ,东莞ai听译平台
SEO优化如何进行:提升网站排名,轻松超越竞争对手,ai写作怎么操作手机
优化整站,让网站飞速增长,打造行业竞争力,广东网站建设与维护
什么是seo优化营销,seo主要优化什么 ,ai绘画国风古韵
seo类文章是什么,seo技术文章 ,ai3.5-ai聊天
ChatGPT当前不可用?如何应对AI服务中断的挑战,ai文章免费写作app
ChatGPT的超链接点不开?解决方法一网打尽!,情感ai写作指令是什么
什么是seo概念,什么是seo,sem ,ai音标谐音
什么是seo方法,何为seo ,ai写作神器源码是什么
为什么做seo的人很少,为了什么做seo ,ai不负你
如何用AI写公众号文章?让创作更高效、更轻松
AI一键生成文章网页版,让内容创作更简单高效
SEO适合-提升网站排名的关键策略,张家口品牌推广营销中心
seo,seoul city ,ai精洗
优化综合:引领高效发展的智慧之道,电影营销的推广方式
AI.生成重新定义创造力的新纪元
SEO知道:让你的网站在搜索引擎中脱颖而出,水安建设集团网站
软件AI:颠覆未来的智能革命
OpenArtAI如何进入:数字艺术的未来之门,分析海报ai
ChatGPT进不去怎么办?解决方案与技巧,轻松畅享智能对话,ai va