MySQL 批量插入,如何不插入重复数据

MySql的唯一性索引unique

^空城

已于 2022-11-22 17:12:37 修改

1557
 收藏 3
文章标签: mysql 数据库 java
版权
目录

一、唯一性索引的使用

创建表时怎么添加唯一性索引

添加唯一性索引

删除唯一性索引

unique与primary key的区别:

二、存在唯一性冲突的避免策略

1.insert ignore:

2.replace into

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。

————————————————
版权声明:本文为CSDN博主「^空城」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_52835003/article/details/127848244

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值