mysql prepare疑问

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql prepare疑问相关的知识,希望对你有一定的参考价值。

向各位前辈请教一个问题,是关于mysql中的prepare语句的。
1、select bj from kq201905 where sfz=vsfz;
这句可以正确查询,其中vsfz是用游标的方式从另一个表中取的值,这句可以正确查询说明这个变量是没有问题的。
2、我为了使用变量做表名实现循环取值,所以使用了拼接语句,第一种写法:set @vsk=concat('select bj from ',vkn,' where sfz=vsfz;');结果显示错误1054,没有vsfz这个字段。
第二种写法:set @vsk=concat('select bj from ',vkn,' where sfz=',vsfz,';');执行时没有报错,但是却得到了一个错误的查询结果。我做了一些试验,发现这个错误与文件名变量无关,与忘记给字符串加引号产生的错误一样。但是语句1可以正确执行又说明变量是没有问题的。
我怎么也找不到错在哪里,请各位前辈指点迷津,谢谢!

vkn和vsfz都是自定义变量吗?那在使用的时候也要带上@:
set @vsk=concat('select bj from ',@vkn,' where sfz=',@vsfz,';');
参考技术A

加日志打印调试下,不建议使用游标,可以用临时表或者视图做处理。还有就是你的变量可能受到查询结果影响的话,最好定义个集合来维护下这个变化过程,跟踪下·

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

以上是关于mysql prepare疑问的主要内容,如果未能解决你的问题,请参考以下文章

mysql怎么区分prepare

MySQL prepare 原理

带有多个 PREPARE 语句的 Mysql 过程问题

php+mysql预查询prepare 与普通查询的性能对比

MySQL 的prepare使用中的bug解析过程

mysql prepare语句使用