[MYSQL]prepare 预编译SQL:Mysql

预编译SQL:

SQL代码
  1. prepare pstmt from 'select a from table';  



上面这句SQL创建了一个预编译的SQL。名为pstmt,这个预编译SQL的存活期就是当前的会话,也就是当前的数据库连接。
如果连接一断开 ,那就会消失。

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

SQL代码
  1. set @sql = 'select * from admin';prepare pstmt from @sql;  



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

比如:

SQL代码
  1. prepare testhex from 0x73656C656374202A2066726F6D2061;  


这样是错误 的,可以先用变量来接收这个十六进制串的值,然后再进行SQL的编译。

SQL代码
  1. set @sql = 0x73656C656374202A2066726F6D2061;prepare testhex from @sql;  


这样就正确了。

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

SQL代码
  1. prepare mutisql from 'select 1;select 2';  


这是错误的。

可以被预编译的SQL语句的型也是有限制的,并不是所有的SQL都可以被编译。
下面这些型的SQL是可以编译的:
create table,delete,do,insert,replace,select,set,update 和多数的show语句。


利用下面的SQL来执行上面的已经编译好的SQL:
execute pstmt; execute后面直接跟名字就可以执行。。

带参数的预编译SQL:

SQL代码
  1. prepare pstmt from 'select a from table where id = ?';  



参数用?代替。注意,就算参数的值是一个字符串,也不用加引号。加了反而有错。

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

SQL代码
  1. set @value = 1;execute pstmt using @value;  



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

多个参数之间用逗号隔开。

删除预编译SQL的办法:

SQL代码
  1. drop prepare a;   


a 是预编译SQL的名字。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值