如何在 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)其它相关文章!
推荐阅读
容器化最佳实践:Docker 与 Kubernetes 在微服务架构中的协同设计
AWS Cloud9 使用攻略:云端 IDE 如何无缝集成 Lambda 与 S3 服务?
Heroku vs AWS Elastic Beanstalk:快速部署 Web 应用的平台对比
Kubernetes 集群部署避坑:资源调度、服务发现与滚动更新策略
Docker 镜像优化指南:分层构建、瘦身技巧与多阶段编译实践
Postman 接口测试全流程:从 API 设计到自动化测试脚本编写
pytest 框架进阶:自定义 fixture、插件开发与持续集成集成方案
JUnit 5 新特性:参数化测试、扩展模型与微服务测试实践
Chrome DevTools 性能分析:FPS 监控、内存快照与网络请求优化指南
GDB 调试核心技巧:多线程调试、内存断点与反汇编分析实战