连续过程中的字符串值

时间:2018-11-22 13:44:03

标签: php mysql stored-procedures concat

我知道我的问题听起来很傻,但是由于这个问题,我无法运行我的代码,我的所有过程都是正确的,我唯一的问题是我无法使用包含字符串的语法,是:

SET @query = CONCAT(@query,'WHERE i.active = T');

我试图在撇号和之间使用+。 ,但是在所有情况下都无法正常工作...

这是完整过程

CREATE PROCEDURE stocktakess()

            BEGIN
              DECLARE wid INT;
              DECLARE wname VARCHAR(20);
              DECLARE query TEXT DEFAULT '';
              DECLARE finished INT DEFAULT 0;
              DECLARE whouse_cursor CURSOR FOR SELECT Id, name FROM warehouse WHERE Id IN (1,2,3,5,8);
              DECLARE CONTINUE HANDLER FOR NOT FOUND SET finished = 1;
              OPEN whouse_cursor;
              SET @query = 'SELECT i.code,i.code2,i.description';
            get_whouse: LOOP
              FETCH whouse_cursor INTO wid, wname;
              IF finished = 1 THEN 
                LEAVE get_whouse;
              END IF;
              SET @query = CONCAT(@query, ', SUM(CASE WHEN m.warehouseID=', wid, ' THEN COALESCE(m.qtyin, 0) - COALESCE(m.qtyout, 0) ELSE 0 END) AS `', wname, '`');
              END LOOP get_whouse;
              SET @query = CONCAT(@query, ' FROM items i LEFT JOIN itemmovement m ON m.itemid = i.Id');
              SET @query = CONCAT(@query, ' WHERE i.active=T');  
              SET @query = CONCAT(@query, ' GROUP BY i.Id');
              PREPARE stmt FROM @query;
              EXECUTE stmt;
              DEALLOCATE PREPARE stmt;
            END

1 个答案:

答案 0 :(得分:-1)

CREATE PROCEDURE stocktakess()

            BEGIN
              DECLARE wid INT;
              DECLARE wname VARCHAR(20);
              DECLARE query TEXT DEFAULT '';
              DECLARE finished INT DEFAULT 0;
              DECLARE whouse_cursor CURSOR FOR SELECT Id, name FROM warehouse WHERE Id IN (1,2,3,5,8);
              DECLARE CONTINUE HANDLER FOR NOT FOUND SET finished = 1;
              OPEN whouse_cursor;
              SET @query = 'SELECT i.code,i.code2,i.description';
            get_whouse: LOOP
              FETCH whouse_cursor INTO wid, wname;
              IF finished = 1 THEN 
                LEAVE get_whouse;
              END IF;
              SET @query = CONCAT(@query, ', SUM(CASE WHEN m.warehouseID=', wid, ' THEN COALESCE(m.qtyin, 0) - COALESCE(m.qtyout, 0) ELSE 0 END) AS `', wname, '`');
              END LOOP get_whouse;
              SET @query = CONCAT(@query, ' FROM items i LEFT JOIN itemmovement m ON m.itemid = i.Id');
              SET @query = CONCAT(@query, ' WHERE i.active=\'T\'');  
              SET @query = CONCAT(@query, ' GROUP BY i.Id');
              PREPARE stmt FROM @query;
              EXECUTE stmt;
              DEALLOCATE PREPARE stmt;
            END