[MYSQL]prepare 预编译SQL:Mysql
来源:互联网 发布:linux系统入门书籍 编辑:程序博客网 时间:2024/06/18 04:26
预编译SQL:
SQL代码
- prepare pstmt from 'select a from table';
上面这句SQL创建了一个预编译的SQL。名为pstmt,这个预编译SQL的存活期就是当前的会话,也就是当前的数据库连接。
如果连接一断开 ,那就会消失。
from后面跟的就是要进行编译的那个SQL,这个值可以是一个字面的字符串值 ,就像上面,也可以是一个变量。
比如:
SQL代码
- set @sql = 'select * from admin';prepare pstmt from @sql;
from后面跟的只能是字面值或者变量这两种情况 ,不能直接跟十六进制的字符串。
比如:
SQL代码
- prepare testhex from 0x73656C656374202A2066726F6D2061;
这样是错误 的,可以先用变量来接收这个十六进制串的值,然后再进行SQL的编译。
SQL代码
- set @sql = 0x73656C656374202A2066726F6D2061;prepare testhex from @sql;
这样就正确了。
注意:被编译的SQL只能是一条单独的语句,不能多条语句一起编译,比如:
SQL代码
- 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代码
- prepare pstmt from 'select a from table where id = ?';
参数用?代替。注意,就算参数的值是一个字符串,也不用加引号。加了反而有错。
在调用的时候利用using关键字向SQL传递参数 。
SQL代码
- set @value = 1;execute pstmt using @value;
先声明一个变量来保存参数的值,然后通过后面的using @value来传SQL传递参数 。
注意这里的参数的值只能由变量来传递,不能直接写成execute pstmt using 1;
这是错误的。
多个参数之间用逗号隔开。
删除预编译SQL的办法:
SQL代码
- drop prepare a;
a 是预编译SQL的名字。
- prepare 预编译SQL:Mysql
- [MYSQL]prepare 预编译SQL:Mysql
- MySQL prepare预编译
- Mysql 中的Prepare 预编译
- mysql prepare
- MySQL prepare语句的SQL语法
- MySQL prepare语句的SQL语法
- MySQL prepare语句的SQL语法
- mysql 问号(?) 预编译
- php mysql 预编译
- 探究mysql预编译
- mysql preparedStatement预编译
- 测试mysql的sql语句预编译效果
- [MYSQL]PREPARE 简单应用
- mysql的prepare应用
- mysql prepare语句使用
- mysql prepare测试
- mysql prepare语句使用
- Windows Vista 原先的设计目标
- 关于多线程中的全局静态变量
- [PHP]php算法
- Google以及那些消逝了的背影
- [MYSQL]PREPARE 简单应用
- [MYSQL]prepare 预编译SQL:Mysql
- 创业投资——非同寻常的大众幻想与群众性癫狂
- 体育的真谛是什么?
- JNI实践(转载)
- 对环境索求越多,越无法进化
- Asp.net把UTF-8编码转换为GB2312编码
- df
- debian(lenny)更改默认语言编码
- aa_demo