一尘不染

将参数传递给MySQL脚本

mysql

我有一个名为的MySQL脚本文件query1.sql,其中包含:

select * FROM $(tblName) LIMIT 10;

我在MySQL控制台中,如何将参数传递给脚本?这不会转发变量:

mysql> \. query1.sql -v tblName=Users

阅读 497

收藏
2020-05-17

共1个答案

一尘不染

您可以使用用户变量来实现您描述的行为。在将变量用作模式标识符而不是数据值时,必须使用准备好的语句,以便可以动态组成查询。

query1.sql

SET @query = CONCAT('Select * FROM ', @tblName, ' LIMIT 10');
PREPARE stmt FROM @query;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

调用为

mysql> SET @tblName = 'Users'; \. query1.sql
2020-05-17