从 MySQL 中的变量表名称中选择数据
在 MySQL 中,您可能会遇到需要从某个表中检索数据的场景,该表的名称是名称存储在变量中。单独使用 SQL 来实现这一点可能很棘手,因为通过表名动态访问表可能会导致错误。
问题:
考虑以下场景:
SET @ID_1 = (SELECT ID FROM `slider` LIMIT 0,1); SET @Cat = (SELECT Category FROM `slider` LIMIT 0,1); select * from @Cat where ID = @ID_1;
运行此查询将导致错误,因为 MySQL 无法将变量 @Cat 解释为有效表name.
解决方案:
要克服此限制,您可以使用准备好的语句:
SET @s = CONCAT('select * from ', @Cat, ' where ID = ', @ID_1); PREPARE stmt1 FROM @s; EXECUTE stmt1; DEALLOCATE PREPARE stmt1;
细分:
此方法允许您动态执行 SQL 查询,其中表名在运行时根据变量 @Cat 和 @ID_1 中存储的值确定。
以上是如何在MySQL中从带有变量名的表中选择数据?的详细内容。更多信息请关注PHP中文网其他相关文章!