2

我想创建一个名称取自用户定义变量的表。以下代码似乎不起作用(我在 CREATE TABLE 行附近收到 MYSQL 语法错误)

在此先感谢您的帮助

SET @ratingsNewTableName = CONCAT('ratings_', 'anotherString');

CREATE TABLE IF NOT EXISTS @ratingsNewTableName (
   `id` INT(11) NOT NULL AUTO_INCREMENT,
   `user_id` INT(11) NOT NULL,
   `movie_id` INT(11) NOT NULL,
   `rate` DOUBLE NOT NULL,
   `date` DATE NOT NULL,
   PRIMARY KEY (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=1;
4

2 回答 2

4
SET @sql := CONCAT('CREATE TABLE IF NOT EXISTS ', @tableName,'( id INT(11) NOT NULL AUTO_INCREMENT, user_id INT(11) NOT NULL, movie_id INT(11) NOT NULL, rate DOUBLE NOT NULL, date DATE NOT NULL, PRIMARY KEY (id) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1' ); 
PREPARE mySt FROM @sql; 
EXECUTE mySt;
于 2010-07-09T09:00:46.967 回答
0

我想创建一个名称取自用户定义变量的表

不是你的问题的答案,但我认为这是一个坏主意。它会招来很多麻烦。

  • 您必须处理表名中的特殊字符和编码

  • 您必须过滤掉表名中禁止使用的字符

  • 可用字符的范围取决于底层文件系统的能力,因为 mySQL 使用表名创建其数据文件

  • 您可能会遇到长期麻烦,因为 mySQL 在不同系统上对表的处理方式不同。区分大小写由底层文件系统决定(表名在 Linux/Unix 上区分大小写,在 Windows 上不区分大小写)

我不会这样做的。我宁愿有一个大表和一个较小的用户表。我会在用户表中保留用户指定的变量,并在巨大的表中保存所有用户的所有记录,并通过“用户”键分开。

于 2010-07-09T09:00:29.590 回答