MySQL数据库存储过程动态表建立(PREPARE)
来源:互联网 发布:女人慵懒的气质知乎 编辑:程序博客网 时间:2024/05/16 08:03
- PREPARE statement_name FROM sql_text /*定义*/
- EXECUTE statement_name [USING variable [,variable...]] /*执行预处理语句*/
- DEALLOCATE PREPARE statement_name /*删除定义*/
这是我项目当中用到的,用作参考使用:
DELIMITER $$DROP PROCEDURE IF EXISTS `gpsdata`.`sp_test`$$CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_test`(gpstime_ varchar(128),gpsname_ varchar(128),gpsinfo_ varchar(256))BEGINDECLARE tbname varchar(50) DEFAULT '0';DECLARE v_sql varchar(1024) DEFAULT '0';SET v_sql=CONCAT('select * from ', tbname ,' where gpsname = ',gpsname_,' order by gpstime desc limit 1');SET @lastdata = v_sql;PREPARE lastdata FROM @lastdata; EXECUTE lastdata;DEALLOCATE PREPARE lastdata; select v_sql;END$$DELIMITER ;
使用 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 句法被支持。
I:PREPARE 语句不可以用于存储过程(5.0以上可以使用),自定义函数!但从 MySQL 5.0.13 开始,它可以被用于存储过程,仍不支持在函数中使用!
0 0
- MySQL数据库存储过程动态表建立(PREPARE)
- mysql prepare 存储过程使用
- mysql prepare 存储过程使用
- 动态存储过程数据库
- mysql数据库存储过程
- mysql数据库存储过程
- MySql数据库存储过程
- MySQL数据库存储过程
- MySql存储过程动态建表
- mysql 存储过程-动态表名
- mysql 存储过程 动态表名
- oracle 利用存储过程为表动态建立索引
- oracle 利用存储过程为表动态建立索引
- jdbc学习:建立数据库表以及存储过程等
- SQL Server 2008 R2 建立数据库,建立表,建立存储过程
- mysql动态分页存储过程
- Mysql 存储过程 动态sql
- mysql 存储过程动态sql
- 使用TFHpple解析html
- MFC ComboBox的使用
- 深入理解Java内存模型(一)——基础
- Ryouko's Memory Note(书本翻页)
- 安装及卸载Windows服务---详细
- MySQL数据库存储过程动态表建立(PREPARE)
- jquery select 动态将制定值设置为默认选定
- CTreeCtrl遍历树上所有可见和不可见的节点
- NSBundle--获取文件路径
- 虚析构函数? vptr? 指针偏移?多态数组? delete 基类指针 内存泄漏?崩溃?
- error: undefined reference to 'typeinfo for FileDialogDelegate'
- ie6,ie7下a标签无法点击
- Linux下TI omap芯片 MUX 配置分析(以AM335X芯片为例)
- 运行时中给一个对象绑定另外一个对象