我正在尝试将表名传递到我的 mysql 存储过程中,以使用此存储过程从不同的表中进行选择,但它不起作用......
这就是我正在尝试的:
CREATE PROCEDURE `usp_SelectFromTables`(
IN TableName varchar(100)
)
BEGIN
SELECT * FROM @TableName;
END
我也试过不带@符号,这只是告诉我TableName不存在......我知道:)
我正在尝试将表名传递到我的 mysql 存储过程中,以使用此存储过程从不同的表中进行选择,但它不起作用......
这就是我正在尝试的:
CREATE PROCEDURE `usp_SelectFromTables`(
IN TableName varchar(100)
)
BEGIN
SELECT * FROM @TableName;
END
我也试过不带@符号,这只是告诉我TableName不存在......我知道:)
SET @cname:='jello';
SET @vname:='dwb';
SET @sql_text = concat('select concept_id,concept_name,',@vname,' from enc2.concept a JOIN enc2.ratings b USING(concept_id) where concept_name like (''%',@cname,'%'') and 3 is not null order by 3 asc');
PREPARE stmt FROM @sql_text;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
额外的一点给我带来了问题。
我想按照@kyle 的要求在查询中动态设置表名和字段,但我也想将该查询的结果存储到查询中的变量@a
中。
您需要将其作为字符串文本的一部分包含在内,而不是将变量@a
放入字面上。concat
delimiter //
CREATE PROCEDURE removeProcessed(table_name VARCHAR(255), keyField VARCHAR(255), maxId INT, num_rows INT)
BEGIN
SET @table_name = table_name;
SET @keyField = keyField;
SET @maxId = maxId;
SET @num_rows = num_rows;
SET @sql_text1 = concat('SELECT MIN(',@keyField,') INTO @a FROM ',@table_name);
PREPARE stmt1 FROM @sql_text1;
EXECUTE stmt1;
DEALLOCATE PREPARE stmt1;
loop_label: LOOP
SET @sql_text2 = concat('SELECT ',@keyField,' INTO @z FROM ',@table_name,' WHERE ',@keyField,' >= ',@a,' ORDER BY ',@keyField,' LIMIT ',@num_rows,',1');
PREPARE stmt2 FROM @sql_text2;
EXECUTE stmt2;
DEALLOCATE PREPARE stmt2;
...Additional looping code...
END LOOP;
END
//
delimiter ;
因此,在使用以下@sql_text1
命令将查询结果分配到@a
字符串中时:
') INTO @a FROM '
然后@sql_text2
用作@a
实际变量:
,' WHERE ',@keyField,' >= ',
@一个,' ORDER BY '
它依赖于 DBMS,但表示法通常需要动态 SQL,并且会遇到函数的返回值在执行时取决于输入的问题。这给了系统conniptions。作为一般规则(因此可能有例外),DBMS 不允许您对查询的结构元素(例如表名或列名)使用占位符(参数);它们只允许您指定值,例如列值。
某些 DBMS 确实具有存储过程支持,允许您构建 SQL 字符串,然后使用“准备”或“立即执行”或类似操作来处理它。但是请注意,您突然容易受到 SQL 注入攻击 - 可以执行您的过程的人随后能够部分控制 SQL 被执行的内容。