文档章节

查询记录是否存在,不存在即插入,存在即更新

xuguangwu
 xuguangwu
发布于 2017/02/15 22:37
字数 188
阅读 83
收藏 0
点赞 0
评论 0

很多业务场景需要这样的操作,对数据或sql不做处理的话,需要做两次sql操作,很繁琐。
以下是我所用的三种解决办法,一步解决。

加唯一索引,如果一个字段不行,那就两个字段建立唯一索引。

如果只使用一个主键值
INSERT INTO auto (k, v) VALUES (1, '1-1') ON DUPLICATE KEY UPDATE v=VALUES(v);
相比于replace into,不会更改主键值,不会破坏主键建立的关系,同时只修改需要更新的数据,原有的数据会保存。

replace into

replace into会修改掉原有的值,主键还会增长,不建议使用

© 著作权归作者所有

共有 人打赏支持
xuguangwu
粉丝 3
博文 20
码字总数 13259
作品 0
深圳
程序员
mongodb update 更新操作

db.collection.update(<query>,// 查询条件<update>, // 要更新的值(字段)--赋值表达式 $set{ }) 1,先查询person 中age=20 的数据: 更新name为“ming”,在次查询,age=20的数据,发现只...

Atom_me ⋅ 2016/05/14 ⋅ 0

SQL Server 和 HSQLDB 中使用 merge into 完成 saveOrUpdate

当我们调用 Hibernate 的 saveOrUpdate() 或 JPA 的 save() 方法的 Hibernate 实现时,都会做两步操作:1)按 ID 查询记录是否已存在,2)不存在插入新记录,存在则更新原记录。这种两步操作...

Unmi ⋅ 06/02 ⋅ 0

MongoDB学习笔记(一)--基础

Insert MongoDB在执行插入时,首先会将插入的数据转换成BSON格式。然后MongoDB数据库会对BSON进行解剖,并检查是否存在_id建。 >doc = { } > db.yyd.insert(doc); Query 全部查找 返回除了 ...

老朱教授 ⋅ 2017/10/01 ⋅ 0

Mysql中INSERT ... ON DUPLICATE KEY UPDATE的实践

一、前言 在日常业务开发中经常有这样一个场景,首先创建一条记录,然后插入到数据库;如果数据库已经存在同一主键的记录,则执行update操作,如果不存在,则执行insert操作; 最近工作也遇到...

阿里加多 ⋅ 03/23 ⋅ 0

MySQL之 INSERT ... ON DUPLICATE KEY UPDATE

一、insert or update需求 需求:如果testtable中存在记录则update,不存在则insert。 二、老做法:3条sql select * from testtable where id = 1; //查询表中是否已有记录insert into test_...

谢思华 ⋅ 2015/08/28 ⋅ 0

MongoDB增删查改

MongoDB条件查询 1.自动注入mongo 2.查询 创建条件对象 Criteria MongoDB条件操作符 创建Query对象 内嵌数组查询表达式 (1) $size,用于查询数组大小为size的记录 db.a.find({"comments":{"...

满小茂 ⋅ 2016/05/04 ⋅ 0

TODO:MongoDB的查询更新删除总结

TODO:MongoDB的查询更新删除总结 常用查询,条件操作符查询,< 、<=、>、>=、!= 对应 MongoDB的查询操作符是$lt、$lte、$gt、$gte、$ne 例: db.getCollection(‘image_detail’).find({“d...

OneTODO ⋅ 2016/11/20 ⋅ 0

MongoDB使用手册--数据更新(Updating)

update() 语法结构是: db.collection.update( criteria, objNew, upsert, multi ) 参数: criteria - 查询需要更新的项; objNew - 更新的对象或者 $ operators (例如 $inc) 这样的操作因子 ...

五味格子 ⋅ 2011/07/15 ⋅ 0

防止ClistCtrl刷新闪烁的五种方法

程序需要从数据库某一个活动表中,定时取数据,更新界面的列表显示,比如有20条数据(变化),则这20数据 不停的变化,(通过其他程序实现) 方案(1),先在列表中查找,后插入比如每条记录...

barsoom ⋅ 2012/12/31 ⋅ 1

部署MongoDB集群

处理多种常见的故障 单节点失效,如何恢复工作 数据库意外被杀死如何进行数据恢复 数据库发生拒绝服务如何排查原因 数据库磁盘快满时如何处理 MongoDB 无数据结构限制: 1. 没有表结构的概念...

Vincent-Duan ⋅ 2015/03/31 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Spring | IOC AOP 注解 简单使用

写在前面的话 很久没更新笔记了,有人会抱怨:小冯啊,你是不是在偷懒啊,没有学习了。老哥,真的冤枉:我觉得我自己很菜,还在努力学习呢,正在学习Vue.js做管理系统呢。即便这样,我还是不...

Wenyi_Feng ⋅ 今天 ⋅ 0

博客迁移到 https://www.jianshu.com/u/aa501451a235

博客迁移到 https://www.jianshu.com/u/aa501451a235 本博客不再更新

为为02 ⋅ 今天 ⋅ 0

win10怎么彻底关闭自动更新

win10自带的更新每天都很多,每一次下载都要占用大量网络,而且安装要等得时间也蛮久的。 工具/原料 Win10 方法/步骤 单击左下角开始菜单点击设置图标进入设置界面 在设置窗口中输入“服务”...

阿K1225 ⋅ 今天 ⋅ 0

Elasticsearch 6.3.0 SQL功能使用案例分享

The best elasticsearch highlevel java rest api-----bboss Elasticsearch 6.3.0 官方新推出的SQL检索插件非常不错,本文一个实际案例来介绍其使用方法。 1.代码中的sql检索 @Testpu...

bboss ⋅ 今天 ⋅ 0

informix数据库在linux中的安装以及用java/c/c++访问

一、安装前准备 安装JDK(略) 到IBM官网上下载informix软件:iif.12.10.FC9DE.linux-x86_64.tar放在某个大家都可以访问的目录比如:/mypkg,并解压到该目录下。 我也放到了百度云和天翼云上...

wangxuwei ⋅ 今天 ⋅ 0

PHP语言系统ZBLOG或许无法重现月光博客的闪耀历史[图]

最近在写博客,希望通过自己努力打造一个优秀的教育类主题博客,名动江湖,但是问题来了,现在写博客还有前途吗?面对强大的自媒体站点围剿,还有信心和可能型吗? 至于程序部分,我选择了P...

原创小博客 ⋅ 今天 ⋅ 0

IntelliJ IDEA 2018.1新特性

工欲善其事必先利其器,如果有一款IDE可以让你更高效地专注于开发以及源码阅读,为什么不试一试? 本文转载自:netty技术内幕 3月27日,jetbrains正式发布期待已久的IntelliJ IDEA 2018.1,再...

Romane ⋅ 今天 ⋅ 0

浅谈设计模式之工厂模式

工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 在工厂模式中,我们在创建对象时不会对客户端暴露创建逻...

佛系程序猿灬 ⋅ 今天 ⋅ 0

Dockerfile基础命令总结

FROM 指定使用的基础base image FROM scratch # 制作base image ,不使用任何基础imageFROM centos # 使用base imageFROM ubuntu:14.04 尽量使用官方的base image,为了安全 LABEL 描述作...

ExtreU ⋅ 昨天 ⋅ 0

存储,对比私有云和公有云的不同

导读 说起公共存储,很难不与后网络公司时代的选择性外包联系起来,但尽管如此,它还是具备着简单和固有的可用性。公共存储的名字听起来也缺乏专有性,很像是把东西直接堆放在那里而不会得到...

问题终结者 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部