首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >mysql创建表语法的问题

mysql创建表语法的问题
EN

Stack Overflow用户
提问于 2022-04-04 12:58:52
回答 2查看 34关注 0票数 -1

我尝试使用以下命令在mysql中创建表:

代码语言:javascript
复制
CREATE TABLE keys (id INT(10), key VARCHAR(100));

它总是给我带来这样的错误:

错误1064 (42000):您的SQL语法出现了错误;请检查与您的MySQL服务器版本相对应的手册,以获得在第1行使用“key”(id INT(10),key VARCHAR(100))的正确语法。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-04-04 13:20:12

因此,表名keys和字段key都保留在Mysql命名空间中。如果您选择一个不同的表名(例如keys_tbl)并重命名第二个字段(类似于key_id ),那么您的代码就可以工作了。

票数 1
EN

Stack Overflow用户

发布于 2022-04-04 13:24:51

您应该非常小心地进行表和列的命名,将来可能会遇到很多问题。

我建议找一些不是MySQL保留字的名字

如果你还想保留名字,你应该放在后面。

代码语言:javascript
复制
mysql> CREATE TABLE keys (id INT(10), key VARCHAR(100));
ERROR 1064 (42000): 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 'keys (id INT(10), key VARCHAR(100))' at line 1

mysql> CREATE TABLE `keys` (id INT(10), `key` VARCHAR(100));
Query OK, 0 rows affected, 1 warning (0.97 sec)

mysql> show create table keys;
ERROR 1064 (42000): 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 'keys' at line 1
mysql>
mysql>
mysql> show create table `keys`;
+-------+-----------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                                                        |
+-------+-----------------------------------------------------------------------------------------------------------------------------------------------------+
| keys  | CREATE TABLE `keys` (
  `id` int DEFAULT NULL,
  `key` varchar(100) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci |
+-------+-----------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.01 sec)

注意,在使用表时必须使用回标

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71737666

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档