问题描述
我需要能够在表名中使用变量-我基本上具有用于不同类型数据的同一组表,因此我只想拥有一个仪表板并在所有类型之间进行交换,而不必总是进行设置多个相同的仪表板。
我的查询类似于:
select * from table_$variable_name;
我的可能变量列表是猫,狗,鸟
我似乎可以做到这一点,如果我只按上面显示的那样放置变量,则会出现以下错误
Error 1146: Table 'table_$variable_name' doesn't exist
如果将其用大括号括起来,则会出现此错误。
Error 1064: You have an error in your sql Syntax; check the manual that corresponds to your MysqL server version for the right Syntax to use near '{bird}' at line 1
(即所选变量这次实际上是可见的)
我不确定问题是否在于表名中是否包含下划线,我也尝试在变量周围加上下划线以进行检查,但我对此没有运气。
我尝试的另一件事是逐渐添加到表名,例如
select * from table_$variable;
仍然返回错误,但是我可以看到表名开始正确地形成
Error 1146: Table 'table_bird_' doesn't exist
但是,一旦我添加下划线,该变量就不会被提取 错误1146:表'table_ $ variable_'不存在
我确定查询语法中缺少这种愚蠢的东西-任何人有任何建议吗?
使用此https://grafana.com/docs/grafana/latest/variables/templates-and-variables/供参考
解决方法
正如@arturomp 建议的那样,使用
${var:raw}
至少在我的情况下,这是有效的解决方案。