MySQL数据库存储过程动态表建立(PREPARE)
Posted zhchoutai
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL数据库存储过程动态表建立(PREPARE)相关的知识,希望对你有一定的参考价值。
- 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) ) BEGIN DECLARE 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 的作用域是当前client连接会话可见。
E: 要释放一个提前定义语句的资源,能够使用 DEALLOCATE PREPARE 句法。
F: EXECUTE stmt_name 句法中,假设 stmt_name 不存在。将会引发一个错误。
G: 假设在终止client连接会话时。没有显式地调用 DEALLOCATE PREPARE 句法释放资源,server端会自己动释放它。
H:在提前定义语句中。CREATE TABLE, DELETE, DO, INSERT, REPLACE, SELECT, SET, UPDATE, 和大部分的 SHOW 句法被支持。
I:PREPARE 语句不能够用于存储过程(5.0以上能够使用),自己定义函数!
但从 mysql 5.0.13 開始,它能够被用于存储过程,仍不支持在函数中使用!
以上是关于MySQL数据库存储过程动态表建立(PREPARE)的主要内容,如果未能解决你的问题,请参考以下文章
Mysql学习---视图/触发器/存储过程/函数/索引 180101