您的位置:首页 > 博客中心 > 数据库 >

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

时间:2022-03-15 03:05

    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

热门排行

今日推荐

热门手游