存储过程中的mysql动态查询

时间:2014-04-20 05:30:57

标签: mysql sql stored-procedures

我在存储过程中创建动态查询。我的存储过程如下:

CREATE PROCEDURE `test1`(IN tab_name VARCHAR(40),IN w_team VARCHAR(40))
BEGIN
SET @t1 =CONCAT("SELECT * FROM ",tab_name," where team=",w_team);
 PREPARE stmt3 FROM @t1;
 EXECUTE stmt3;
 DEALLOCATE PREPARE stmt3;
END

当我尝试使用以下调用运行它时:

call test1 ('Test','SPA');

我收到以下错误消息:

  

错误代码:1054。未知栏' SPA'在' where子句'

我在没有条件的情况下进行了测试并且工作正常,但是当where条件不起作用时,我尝试使用带变量名的@但它仍然不起作用。

感谢您的帮助。

4 个答案:

答案 0 :(得分:6)

试试这个..

CREATE PROCEDURE `test1`(IN tab_name VARCHAR(40),IN w_team VARCHAR(40))
BEGIN
SET @t1 =CONCAT("SELECT * FROM ",tab_name," where team='",w_team,"'");
 PREPARE stmt3 FROM @t1;
 EXECUTE stmt3;
 DEALLOCATE PREPARE stmt3;
END

你在w_team变量周围缺少引号..

你应该打印动态构建的语句,这样你就可以复制打印的语句并尝试这样就可以轻松找到这种问题。

select @ t1将打印动态构建的语句..

答案 1 :(得分:5)

试试这样:

SET @t1 =CONCAT("SELECT * FROM ",tab_name," where team='",w_team,"'");

<强>解释

之前的动态查询将如下:

SELECT * FROM Test where team=SPA

我们将其更改为:

SELECT * FROM Test where team='SPA'

答案 2 :(得分:5)

  

错误代码:1054。未知栏&#39; SPA&#39;在&#39; where子句&#39;

如果未将输入字符串括在引号内,并且SQL引擎尝试将其标识为要查询的表中的列,则会发生这种情况。但它失败了,因为它无法找到它。

但是当它找到这样的列时会发生什么? 它在列值上找到一些匹配时获取结果 显然这不是人们所期待的。

如何克服这个?将Prepared Statements与动态输入值一起使用。

您也可以在存储过程中使用?等占位符来动态输入值,以便与Prepared Statements一起使用。在SQL表达式中分配或比较引擎时,引擎将处理转义字符和其他字符串值。

您只需根据需要将过程输入重新分配给一个或多个会话变量。

您的程序示例

CREATE PROCEDURE `test1`( IN tab_name VARCHAR(40), IN w_team VARCHAR(40) )
BEGIN
  SET @t1 = CONCAT( 'SELECT * FROM ', tab_name, ' where team = ?' ); -- <-- placeholder
  SET @w_team := w_team;

  PREPARE stmt3 FROM @t1;
  EXECUTE stmt3 USING @w_team; -- <-- input for placeholder
  DEALLOCATE PREPARE stmt3;
END;

答案 3 :(得分:0)

您可以使用 CONCAT() MySQL 函数添加动态字段和条件。我检查过这工作正常。

 DELIMITER $$
 /*define procedure name*/
 CREATE PROCEDURE getSearchData()
 BEGIN
 
 DECLARE conditions varchar(1000);
 DECLARE selectField varchar(1000);
 DECLARE SQL_QUERY  varchar(1000);   

 /*define  default select and condition*/
 SET @selectField = 'status,id';
 set @conditions = ' where return_flight=0'; 

 SET @SQL_QUERY = CONCAT('SELECT ',@selectField, ' FROM flights ',@conditions);   
/* you can add more select fields and conditions according to your requirement */ 

PREPARE stmt1 FROM @SQL_QUERY ;
EXECUTE stmt1;
DEALLOCATE PREPARE stmt1;
END$$
DELIMITER ;