mysql 利用唯一索引Unique 高并发创建不重复唯一订单号是不是和兴?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 利用唯一索引Unique 高并发创建不重复唯一订单号是不是和兴?相关的知识,希望对你有一定的参考价值。
这样做会不会对数据库造成影响? 比如大量错误?
本来就需要去做验证查看是否存在,想如果这么做验证都省了,就是不知道有什么缺点
建议你生成订单号的工具最好是那种随机数,或者是有规律递增的,那样就不会有很多重复的了 参考技术A 订单号建索引挺好的啊 ,这样查询还快
MySql的唯一性索引unique
目录
3.insert on duplicate key update
记录学习MySQL唯一性索引的使用及存在唯一性冲突的避免策略
一、唯一性索引的使用
创建表时怎么添加唯一性索引
CREATE TABLE `sc` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(200) CHARACTER SET utf8 DEFAULT NULL,
`class` varchar(200) CHARACTER SET utf8 DEFAULT NULL,
`score` int(11) DEFAULT NULL,
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`create_user_id` bigint(11) DEFAULT NULL COMMENT '创建人id',
`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '最后修改时间',
`update_user_id` bigint(11) DEFAULT NULL COMMENT '最后修改人id',
PRIMARY KEY (`id`),
UNIQUE KEY `name_class` (`name`,`class`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='学生信息表';
在其中创建了唯一索引'name_class'('name','class'),就是说这个学生表同名同班级的学生只能由一位。
添加唯一性索引
alter table sc add unique key `name_score` (`name`,`score`);
为sc表添加一个唯一性索引'name_score'('name','score')
删除唯一性索引
alter table sc drop index `name_score`;
删除名为‘name_score’的唯一性索引
unique与primary key的区别:
简单的讲,primary key=unique+not null
具体的区别:
(1) 唯一性约束所在的列允许空值,但是主键约束所在的列不允许空值。
(2) 可以把唯一性约束放在一个或者多个列上,这些列或列的组合必须有唯一的。但是,唯一性约束所在的列并不是表的主键列。
(3) 唯一性约束强制在指定的列上创建一个唯一性索引。在默认情况下,创建唯一性的非聚簇索引,但是,也可以指定所创建的索引是聚簇索引。
(4) 建立主键的目的是让外键来引用.
(5) 一个表最多只有一个主键,但可以有很多唯一键
二、存在唯一性冲突的避免策略
1.insert ignore:
insert ignore into sc (name,class,score) values ('吕布','二年二班',77)
insert ignore能忽略重复数据,只插入不重复的数据
2.replace into
replace into sc (name,class,score) values ('吕布','二年二班',77);
- 如果存在重复数据,则删除原有的行后,再插入新行,如有自增id,这个会造成自增id的改变。
- 使用insert into,你必须具有insert和update权限。
- 如果有新记录被插入,则受影响行的值显示1;如果原有的记录被更新,则受影响行的值显示2;如果记录被更新前后值是一样的,则受影响行数的值显示0。
3.insert on duplicate key update
insert into sc (name,class,score) values ('关羽','二年二班',80) on duplicate key update score=100;
在遇到重复行时,会直接更新原有的行,具体更新哪些字段怎么更新,取决于update后的语句。
以上是关于mysql 利用唯一索引Unique 高并发创建不重复唯一订单号是不是和兴?的主要内容,如果未能解决你的问题,请参考以下文章