如何在 MySQL 表的多个列上设置 PRIMARY KEY?

实际上,MySQL允许我们在多个列上设置PRIMARY KEY。这样做的优点是我们可以将多个列作为单个实体进行处理。

示例

我们通过在多个列上定义复合主键来创建表分配,如下所示 –

mysql> Create table allotment(
RollNo Int, Name Varchar(20), RoomNo Int, PRIMARY KEY(RollNo, RoomNo));
Query OK, 0 rows affected (0.23 sec)

mysql> Describe allotment;

+——–+————-+——+—–+———+——-+
| Field| Type| Null | Key | Default | Extra |
+——–+————-+——+—–+———+——-+
| RollNo | int(11)| NO| PRI | 0||
| Name| varchar(20) | YES|| NULL||
| RoomNo | int(11)| NO| PRI | 0||
+——–+————-+——+—–+———+——-+

3 rows in set (0.10 sec)

登录后复制

现在,当我们尝试在两列中插入重复的复合值时,MySQL 会抛出如下错误 –

mysql> Insert Into allotment values(1, ‘Aarav’, 201),(2,’Harshit’,201),(1,’Rahul ‘,201);
ERROR 1062 (23000): Duplicate entry ‘1-201’ for key ‘PRIMARY’

登录后复制

以上就是如何在 MySQL 表的多个列上设置 PRIMARY KEY?的详细内容,更多请关注恰卡编程网(mip.qiaqa.com)其它相关文章!

发布于 2023-08-29 20:27:04
分享
海报
168
上一篇:在 Linux 上安装 MongoDB 社区版 4.0下一篇:MySQL中如何找到字符串中子字符串第一次出现的位置?
目录

    忘记密码?

    图形验证码