zoukankan      html  css  js  c++  java
  • MySQL数据库存储过程动态表建立(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 的作用域是当前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 開始,它能够被用于存储过程,仍不支持在函数中使用!

  • 相关阅读:
    字符串比较,栈溢出引起的程序bug
    C语言实现的矩阵乘法运算器
    n阶魔方阵(奇数阵)的输出
    文件的上传和下载---以图片为例
    数据列表的分页显示---前端及后台
    表单重复提交的解决方法
    JAVA基础----持续更新
    Servlet---基础、转发重定向、编码问题解析
    JDBC的链接及封装
    com.mysql.jdbc.connection和java.sql.connection的区别
  • 原文地址:https://www.cnblogs.com/zhchoutai/p/7172115.html
Copyright © 2011-2022 走看看