MySQL变量存储数据库名称
我有一个很长的脚本,需要在几个不同的数据库上运行(所有数据库都具有相同的表和字段名称)。
我想做的是这样的:
1 SET @TARGET_DATABASE = 'beta'
2 SET @SOURCE_DATABASE = 'sandbox';
3
4 CREATE DATABASE IF NOT EXISTS @TARGET_DATABASE;
5 USE @TARGET_DATABASE;
...
10 INSERT INTO `tableFoo` SELECT * FROM @SOURCE_DATABASE.`tableFoo`;
在第 10 行我得到一个错误(我并不感到惊讶):“脚本行:10 你的 SQL 语法有错误;检查与你的 MySQL 服务器版本相对应的手册以便在第 10 行的 '@SOURCE_DATABASE.tableFoo
' 附近使用正确的语法...”
因此我尝试在第 10 行插入此命令:
10 SET @TABLE=CONCAT('`',@SOURCE_DATABASE,'`','.`tableFoo`');
11 INSERT INTO `tableFoo` SELECT * FROM @TABLE;
...并再次出现错误“脚本行:11 您有一个错误在你的 SQL 语法中;检查与你的 MySQL 服务器版本相对应的手册,以获取在行附近“@TABLE”处使用的正确语法...”如你所见,第 10 行工作正常...
有什么方法可以参考吗到数据库中带有变量的表?
// 谢谢。
I have a long script that I need to run on several different databases (all witht he same tables and field names).
What I would like to do is something like this:
1 SET @TARGET_DATABASE = 'beta'
2 SET @SOURCE_DATABASE = 'sandbox';
3
4 CREATE DATABASE IF NOT EXISTS @TARGET_DATABASE;
5 USE @TARGET_DATABASE;
...
10 INSERT INTO `tableFoo` SELECT * FROM @SOURCE_DATABASE.`tableFoo`;
On line 10 I get an error (I'm not surprised): "Script line: 10 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 '@SOURCE_DATABASE.tableFoo
' at line..."
So I tried this insted for line 10:
10 SET @TABLE=CONCAT('`',@SOURCE_DATABASE,'`','.`tableFoo`');
11 INSERT INTO `tableFoo` SELECT * FROM @TABLE;
...and again error "Script line: 11 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 '@TABLE' at line..." As you can see, line 10 works fine...
Is there any way to refer to a table in a database with a variable?
// Thank you.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
如果您连接整个查询,它将起作用。尝试:
It will work if you concat the entire query. Try: