java oralce merge_Oracle数据库merge into的使用,存在则更新,不存在则插入

1、在实际应用场景中,我们会用到:如果这条数据在表中,就更新数据;如果不存在这条数据,就插入这条数据。

在oracle中,可以使用merge into实现,在mysql中可以使用ON DUPLICATE KEY UPDATE,这里只介绍oracle中的merge into实现方法,sql语法如下:

merge into testtable t using dual on (t.id = '1')

when not matched then insert (id,a,b) values (1,2,1)

when matched then update set b = b+1;

select * from testtable;(如果testtable是空表,执行上述语句之后如下:)

id A B

---------------

1 2 1

select * from testtable;(如果再执行一次merge into,testtable结果)

id A B

---------------

1 2 2

解释:

using dual on (...)是一种固定写法,也可以写成 using (select 1 from dual) on (...) , 表名dual也可以写成其他的名字。

on(...)里面是条件,可以写一个条件,也可以用and连多个条件。

2、顺便介绍一下mybatis中怎么使用merge into,直接上代码,代码使用的是动态sql。

merge into staff_evaluation t

using dual on (t.login_id = #{loginId,jdbcType=VARCHAR})

when not matched then insert

USER_ID,

LOGIN_ID,

USER_NAME,

COMPLEX_SCORE,

MOBILE_SERVICE_SCORE,

BROADBAND_SCORE,

KEEP_SCORE,

STATE,

EVALUATE_TEXT,

BEGIN_TIME,

END_TIME,

EVALUATE_PERSON,

#{userId,jdbcType=VARCHAR},

#{loginId,jdbcType=VARCHAR},

#{userName,jdbcType=VARCHAR},

#{complexScore,jdbcType=VARCHAR},

#{mobileServiceScore,jdbcType=VARCHAR},

#{broadbandScore,jdbcType=VARCHAR},

#{keepScore,jdbcType=VARCHAR},

#{state,jdbcType=VARCHAR},

#{evaluateText,jdbcType=VARCHAR},

#{beginTime,jdbcType=VARCHAR},

#{endTime,jdbcType=VARCHAR},

#{evaluatePerson,jdbcType=VARCHAR},

when matched then update

t.COMPLEX_SCORE = #{complexScore,jdbcType=VARCHAR},

t.MOBILE_SERVICE_SCORE = #{mobileServiceScore,jdbcType=VARCHAR},

t.BROADBAND_SCORE = #{broadbandScore,jdbcType=VARCHAR},

t.KEEP_SCORE = #{keepScore,jdbcType=VARCHAR},

t.EVALUATE_TEXT = #{evaluateText,jdbcType=VARCHAR},

t.BEGIN_TIME = #{beginTime,jdbcType=VARCHAR},

t.END_TIME = #{endTime,jdbcType=VARCHAR},

t.EVALUATE_PERSON = #{evaluatePerson,jdbcType=VARCHAR},

where t.LOGIN_ID = #{loginId,jdbcType=VARCHAR}

注意:一定要用update标签。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/419781.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DataTable操作

DataTable操作 一 复制DataTable中符合条件的DataRow到新的DataTable中 One: DataTable TableTemp new DataTable();//临时table DataTable tableAd new Web.DAL.FreeBase().TranSQLGetTable("select a.ClassName,b.ParentId,b.Name,b.Pic,b.Url,b.Sorts fro…

java观察者模式_Java 观察者模式

网上商店中的商品在名称、价格发生变化时,必须自动通知会员,Java的API为我们提供了Observer接口和Observable类来实现所谓观察者模式。Observable(可观察者)类允许在自身发生改变时,通知其它对象(实现接口Observer,观察者)。下面是…

(剑指Offer)面试题5:从尾到头打印链表

题目: 输入一个链表的头结点,从尾到头反过来打印每个结点的值。 链表结点定义: struct ListNode{int value;ListNode* pNext; }; 思路: 1、改变链表结构的话,先反转链表,然后从头到尾打印每个结点的值。&am…

java解析json数组对象_JAVA中快速解析JSON对象里包含的JSON数组

例如现在有这样一个JsonString Value {"data":[{"school_name":"西北农林科技大学","school_id":"8"},{"school_name":"西北大学","school_id":"6"},{"school_name":&…

ACM water

1000 纯属适应题 1003 做的时候花了很久,现在看好像也不难 1004 适应题,求下平均就行 1005 要读懂题就行 1007 逆序数,discuss方法 1046 全部暴搜一遍。。 1118 照抄2606没看题。。WA。。RE全占了 1207 貌似我的方法超级麻烦 1247 …

java水印图片_JAVA实用案例之图片水印开发

写在最前面上周零零碎碎花了一周的时间研究水印的开发,现在终于写了个入门级的Demo,做下笔记同时分享出来供大家参考。Demo是在我上次写的 JAVA实用案例之文件导入导出(POI方式) 框架基础上搭建的,基于SpringSpringMVC。如果有错误还请大家指…

openoffice转换过程中遇到繁体字文档转换失败的问题

今天发现上线的文档转换功能中存在一个文档转换不成功,查看后台日志标志文档无法加载成功,提示日志如下: INFO: connected Jul 08, 2015 2:50:33 PM com.artofsolving.jodconverter.openoffice.connection.AbstractOpenOfficeConnection conn…

java导出excel文件名_怎么解决java导出excel时文件名乱码

怎么解决java导出excel时文件名乱码发布时间:2020-06-19 16:59:00来源:亿速云阅读:137作者:元一java解决导出Excel时文件名乱码的方法示例:String agent request.getHeader("USER-AGENT").toLowerCase();re…

error LNK2038: 检测到“RuntimeLibrary”的不匹配项: 值“MDd_DynamicDebug”不匹配值“MTd_StaticDebug”...

今日VS2012 C编译出现一堆错误: 1 1> 正在生成代码...2 1>Code.obj : error LNK2005: "public: __thiscall std::_Container_base12::_Container_base12(void)" (??0_Container_base12stdQAEXZ) 已经在 msvcprtd.lib(MSVCP110D.dll) 中定义3 1>Code.obj …

adreno630gpu参数_adreno630gpu参数_高通骁龙430参数性能 Adreno505 GPU/20nm制程

高通最新骁龙430八核处理器曝光,具体型号为MSM8937,那么这颗高通骁龙430 MSM8937八核处理器参数和性能表现如何,跑分多少呢,本文带来相关规格的解析。9月15日,高通对外发布了最新低端处理器骁龙430和中端处理器骁龙617…

前端学习(1537):为什么使用ng

传统输入页面值1 传统加法运算

Eclips将lib打入war中

在项目的属性, java build path -> Libraries -> Add library.. -> Web app Libraries 。即可。 在属性中, Deployment Assembly ->add -> project 或者 java build path entries. 这个是一半jar到处。对于WAR 没用。 Eclipse中关于JRE S…

file相对路径java_浅谈java 中文件的读取File、以及相对路径的问题

一、对于java项目中文件的读取1、使用system 或是 系统的properties对象①直接是使用 string relativelypathsystem.getproperty("user.dir");②使用properties对象我们先来遍历一下系统的属性:properties properties system.getproperties();enumeratio…

C#开发Unity游戏教程之判断语句

C#开发Unity游戏教程之判断语句 游戏执行路径的选择——判断 玩家在游戏时,无时无刻不在通过判断做出选择。例如,正是因为玩家做出的选择不同,才导致游戏朝着不同的剧情发展,因此一个玩家可以对一个游戏百玩不厌!既然提…