MySQL 批量插入,如何不插入重复数据?
发布日期:2021-06-30 12:59:27
浏览次数:2
分类:技术文章
本文共 1253 字,大约阅读时间需要 4 分钟。
点击关注公众号,Java干货及时送达
温故而知新
1、insert ignore into
INSERT IGNORE INTO user (name) VALUES ('telami')
这种方法很简便,但是有一种可能,就是插入不是因为重复数据报错,而是因为其他原因报错的,也同样被忽略了~
2、on duplicate key update
当primary或者unique重复时,则执行update语句,如update后为无用语句,如id=id,则同1功能相同,但错误不会被忽略掉。
例如,为了实现name重复的数据插入不报错,可使用一下语句:
INSERT INTO user (name) VALUES ('telami') ON duplicate KEY UPDATE id = id
这种方法有个前提条件,就是,需要插入的约束,需要是主键或者唯一约束(在你的业务中那个要作为唯一的判断就将那个字段设置为唯一约束也就是unique key)。
3、insert … select … where not exist
根据select的条件判断是否插入,可以不光通过primary 和unique来判断,也可通过其它条件。例如:
INSERT INTO user (name) SELECT 'telami' FROM dual WHERE NOT EXISTS (SELECT id FROM user WHERE id = 1)
这种方法其实就是使用了mysql的一个临时表的方式,但是里面使用到了子查询,效率也会有一点点影响,如果能使用上面的就不使用这个。
4、replace into
如果存在primary or unique相同的记录,则先删除掉。再插入新记录。
REPLACE INTO user SELECT 1, 'telami' FROM books
这种方法就是不管原来有没有相同的记录,都会先删除掉然后再插入。另外,关注公众号Java技术栈,在后台回复:面试,可以获取我整理的 MySQL 面试题和答案。
实践
选择的是第二种方式
insert into user (id,username,mobile_number) values ( #{item.id}, #{item.username}, #{item.mobileNumber} ) ON duplicate KEY UPDATE id = id
最后,关注公众号Java技术栈,在后台回复:面试,可以获取我整理的 Java、MySQL 系列面试题和答案,非常齐全。
作者:telami
来源:https://www.telami.cn/
关注Java技术栈看更多干货
获取 Spring Boot 实战笔记!
转载地址:https://javastack.blog.csdn.net/article/details/115499766 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
哈哈,博客排版真的漂亮呢~
[***.90.31.176]2024年04月12日 16时02分44秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
使用协议进行通信
2019-05-01
IDEA 集成Lombok 插件-安装插件
2019-05-01
IDEA 集成Lombok 插件-配置注解处理器
2019-05-01
IDEA 集成Lombok 插件-使用插件
2019-05-01
从Servlet 到ApplicationContext
2019-05-01
高仿真的类-业务逻辑注入接口
2019-05-01
高仿真的类-自动注入
2019-05-01
高仿真的类-页面交互
2019-05-01
高仿真的类-请求url
2019-05-01
高仿真的类-请求参数映射
2019-05-01
高仿真的类-单例工厂的顶层设计
2019-05-01
高仿真的类-BeanDefinition
2019-05-01
高仿真的类-BeanWrapper
2019-05-01
高仿真的类-AbstractApplicationContext
2019-05-01
高仿真的类-DefaultListableBeanFactory
2019-05-01
高仿真的类-ApplicationContext
2019-05-01
高仿真的类-BeanDefinitionReader
2019-05-01
高仿真的类-ApplicationContextAware
2019-05-01
完成DI 依赖注入功能
2019-05-01
MVC 顶层设计-DispatcherServlet
2019-05-01