mysql 平台查询定义变量_查询中的mysql用户定义变量

使用预备陈述:

SET @tablename = 'mytable';

SET @query = CONCAT('SELECT * FROM ', @mytable);

PREPARE stmt FROM @query;

EXECUTE stmt;

DEALLOCATE PREPARE stmt;

如果您的实际查询要复杂得多,您可以在一些存储函数中包装查询的构建:

DELIMITER //

CREATE FUNCTION GetQuery(tableName VARCHAR(50)) RETURNS VARCHAR(100)

BEGIN

DECLARE finalQuery VARCHAR(100);

SET finalQuery = CONCAT('SELECT * FROM ', tableName);

-- do something fancier with finalQuery here

RETURN finalQuery;

END //

DELIMITER ;

SET @query = GetQuery('mytable');

PREPARE stmt FROM @query;

EXECUTE stmt;

DEALLOCATE PREPARE stmt;

更好的是:在存储过程中执行所有操作:

DELIMITER //

CREATE PROCEDURE QueryTable(tableName VARCHAR(50))

BEGIN

SET @finalQuery = CONCAT('SELECT * FROM ', tableName);

PREPARE stmt FROM @finalQuery;

EXECUTE stmt;

DEALLOCATE PREPARE stmt;

SET @finalQuery = NULL;

END //

DELIMITER ;

CALL QueryTable('mytable');

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值