码迷,mamicode.com
首页 > 数据库 > 详细

MySQL数据库存储过程动态表建立(PREPARE)

时间:2014-06-20 11:22:00      阅读:279      评论:0      收藏:0      [点我收藏+]

标签:mysq   l数据库   存储过程   动态表   prepare   

  1. PREPARE statement_name FROM sql_text /*定义*/   
  2. EXECUTE statement_name [USING variable [,variable...]] /*执行预处理语句*/   
  3. 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 的作用域是当前客户端连接会话可见。


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 开始,它可以被用于存储过程,仍不支持在函数中使用!

MySQL数据库存储过程动态表建立(PREPARE),布布扣,bubuko.com

MySQL数据库存储过程动态表建立(PREPARE)

标签:mysq   l数据库   存储过程   动态表   prepare   

原文地址:http://blog.csdn.net/undoner/article/details/28594845

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!