INSERT 表名(字段) VALUES(字段值) ON DUPLICATE KEY UPDATE 条件语句实例

时间:2024年03月30日

/

来源:网络

/

编辑:佚名

INSERT...ON DUPLICATE KEY UPDATE...语句
首先这个的出现一般伴随着UPDATE 语句。我们先来想这样一种场景,我要对数据库中的一条记录,进行新增或者修改,但是呢又不想自己去判断里面是否有,说白了 就是两次查询。
//查今天,这个租户下没有的话插入,有的话+1
StaticActionInfo staticActionInfo = staticActionInfoDao.findStaticActionInfoB
if(staticActionInfo == null){
staticActionInfo model = new StaticActionInfo();
model.setApplication_uri(uri);
model.setAction_number(1L);
model.setTenant_id(tenantId);
model.setPerson_name(tokenService.getLoginUserName());
model.setPerson_id(tokenService.getLoginUserId());
model.setCreate_time(new Date() );
model.setUpdate_time(new Date() );
staticActionInfoDao.saveActionInfo(model);
}else {
staticActionInfo.setAction_number(staticActionInfo.getAction_number() +1);
staticActionInfo.setUpdate_time(new Date() );
staticActionInfoDao.updateActionInfoCountByOption(staticActionInfo);
}

通过一行sql搞定。
INSERT INTO t_user(id,name,age) VALUES (1,'张三',25) 
ON DUPLICATE KEY UPDATE name='张小三',age=30;
代码层面的东西其实没有能省略,两个sql合为了一个而且update的具体操作必须在数据库里完成,比如这里的+1。
猜你需要

豫ICP备2021026617号-1  豫公网安备:41172602000185   Copyright © 2021-2028 www.78moban.com/ All Rights Reserved

本站作品均来自互联网,转载目的在于传递更多信息,并不代表本站赞同其观点和对其真实性负责。如有侵犯您的版权,请联系 1565229909#qq.com(把#改成@),我们将立即处理。