MySql中的有条件插入 insert where
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySql中的有条件插入 insert where,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1629字,纯文字阅读大概需要3分钟。
内容图文
假设现在我们有这样的需求:当数据库中不存在满足条件的记录时,可以插入一条记录,否则程序退出。该怎么实现?
1年以上工作经验的人应该都能立即想到:去检查一下库里有没有记录,没有就插入,有就结束。
int count = selectFromDb(); // ①
if count > 0 {
return;
} else {
insertIntoDb(); // ②
}
2年以上工作经验的在写完上面的逻辑后会立即发现:在并发场景下这样并不安全。如果两个线程同时执行到①这里,都会发现数据库没有记录,于是分别执行了②。所以在并发场景下,这里需要使用分布式锁。
int count = selectFromDb(); // ①
if count > 0 {
return;
} else {
try (getLock()) {// ③
count = selectFromDb(); // ④
if (count == 0) {
insertIntoDb(); // ②
}
}
}
这里在③处加了分布式锁,然后看一下的确没有数据再插入。
这篇文章要说的是使用数据库的sql执行机制来保证并发锁的实现。当然了,如果条件允许,使用唯一键冲突也是可以的。
在我们日常处理数据的时候,都是可以使用条件的,比如最简单的select where,最普通的update where等等。如果我们在插入的时候也可以使用where这个问题不就解决了吗。
当然了,正因为mysql没有提供这种语法,所以我们才在这里讨论这个问题。
mysql提供了根据已有数据来插入表的机制,就是非著名的insert select。所以我们的突破口就在这里,既然这里有select我们就在这里的select加where,因为insert select的实现是select不出东西的时候是不会插入的。
所以这里我们这样写
insert into t(id, c1, c2) select 1, "","" from dual where not exists (select * from t where c1="")
这里的where c1=""
假设就是我们的条件①。
MySql中的有条件插入 insert where
标签:现在 int 处理 根据 class 线程 日常 插入 into
本文系统来源:https://www.cnblogs.com/somefuture/p/14105436.html
内容总结
以上是互联网集市为您收集整理的MySql中的有条件插入 insert where全部内容,希望文章能够帮你解决MySql中的有条件插入 insert where所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。