MYSQL 在主键上建立唯一索引
问题描述
刚到这个公司上班,查看他们的数据库,发现他们竟然在主键上又建立了一次唯一索引,请问这个是怎么回事,是很高明的写法呢,还是很垃圾的写法,我感到很莫名其妙?
我看了,很多表都是这样的情况
CREATE TABLE `tbl_nvhl_order` ( `UUID` varchar(32) NOT NULL COMMENT ’订单号。’, `CHANNEL_ORDER_ID` varchar(50) DEFAULT ’’ COMMENT ’渠道订单号’, ... `ISGROUP` varchar(10) DEFAULT NULL COMMENT ’团单标识’, PRIMARY KEY (`UUID`), UNIQUE KEY `PK_TBL_NVHL_ORDER` (`UUID`) USING BTREE, KEY `index_name` (`CHANNEL_ORDER_ID`,`SOURCE`) USING BTREE, KEY `idx_creator` (`CREATOR`) USING BTREE, KEY `productcode` (`PRODUCTCODE`), KEY `index_app_id` (`APP_ID`) USING BTREE) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT=’’
其中
PRIMARY KEY (`UUID`),UNIQUE KEY `PK_TBL_NVHL_ORDER` (`UUID`) USING BTREE,
求大神指点!
问题解答
回答1:肯定是后者呀。
高性能mysql中就特别指出这种情况,这种情况属于重复索引。在进行更新操作的时候,还需要维护两个索引,性能开销增多了。
回答2:肯定多余了,并且是uuid做主键,也是个坑,这是开发自建的吧
回答3:不太好,能不用最好别用这种方式。
相关文章:
1. 修改mysql配置文件的默认字符集重启后依然不生效2. mongodb - windows7下mongod无法正常启动3. angular.js - 关于指令link 中的创建变量问题4. mysql - 请教一个Java做数据库缓存的问题5. php - 类似Apple官网顶部3级导航该如何设计数据库?6. javascript - ueditor引入报错问题7. python sqlite3 长语句插入出错8. 请问一下各位老鸟 我一直在学习独孤九贱 现在是在tp5 今天发现 这个系列视频没有实战9. javascript - 豆瓣的这个自适应是怎么做的?10. 作为新手,未定义索引username,求解,谢谢

网公网安备