Chinaunix首页 | 论坛 | 博客
  • 博客访问: 85101
  • 博文数量: 65
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 500
  • 用 户 组: 普通用户
  • 注册时间: 2014-04-30 11:16
个人简介

cuug

文章分类
文章存档

2014年(65)

我的朋友

分类: Oracle

2014-05-20 11:08:24

在JAVA开发中通常碰到这样的需求,如果一条数据在表中已经存在,对其做update,如果不存在,将新的数据插入.

如果不使用Oracle提供的merge语法的话,可能先要上数据库select查询一下看是否存在,然后决定怎么操作,这样的话需要写更多的代码,


同时性能也不好,要来回数据库两次.


使用merge的话则可以一条SQL语句完成.




下面是JAVA代码的示例:(这里简单起见,没有对异常下连接关闭做处理)




    private static void testMerge() throws SQLException {


        // create table testtb(id int,val varchar2(10))
        
        String sqlstr = "merge into testtb " 
                + "using (select ? as newid,? as newval from dual) newData "
                + "ON (testtb.id=newData.newid) " 
                + "WHEN NOT MATCHED THEN " 
                + "INSERT VALUES (newid,newval) "
                + "WHEN MATCHED THEN " + "UPDATE SET testtb.val=newData.newval";


        Connection conn = NONXADBUtil.getConnection("jdbc:oracle:thin:@147.151.100.19:1521:orcl", "user", "pwd");


        PreparedStatement sta = conn.prepareStatement(sqlstr);
        
        sta.setInt(1, 1);
        sta.setString(2, "new value");
        
        sta.executeUpdate();


        sta.close();
        conn.commit();
        conn.close();


    }
阅读(502) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~