常规insert语法就不说了,还有些特殊用法

1.  insert all

 into table1(col1,col2) values(v1,v2)

 into table2(col1,col2) values(v1,v2)

......

select ...;

后面的select直接影响前面的into,查询出的每条记录分别执行一次into

示例:

insert all into t_banks values(id,name,al_name) select * from t_banks; --t_banks表中的数据会加倍,values是后面select出的列名

insert all into t_banks values('1','1','1') select 1 from dual; --t_banks表插入一条记录('1','1','1')

2. insert all/first
    when ? then
        into table1(col1,col2) values(v1,v2)
    when ? then
        into table2(col1,col2) values(v1,v2)
    else
        into table3(col1,col2) values(v1,v2)
    select ...;

all有条件的插入,会依次判断每个符合的条件然后into

first有条件的插入,会找到第一个满足的条件然后into,后面的就不判断了

ps:业务中有这样的场景,如果有满足条件的记录就不插入,否则插入。

单线程下先select再insert是ok的,但是如果用户通过界面同时操作就有可能在数据库插入同一数据。

解决方法如下

  • 在service层对方法synchronized,粗暴有效

   如果项目需要集群就不好控制了

  • 数据库层面,在表上加唯一约束,需要动表

   场景:现有一张表存借款需求,每条需求有一个编号,如果有在处理中的需求,相同编号的借款需求不允许再次插入,否则可以再次把借款需求插入表,进行处理

   解决:表上加一个字段SEQ,存同一编号的多条记录的序号1,2,3,4......,编号和SEQ添加唯一键

      这个时候如果表中已有数据,使用下面的sql为已有数据添加SEQ

      merge into t_loan_request lr

      using(

        select decode(rownum-min_sno,0,1,rownum+1-min_sno)sno,a.lr_id

        from

        (select lr_applyid,lr_id from t_loan_request order by lr_applyid,lr_id)a,

        (select lr_applyid,min(rownum) min_sno

        from(select lr_applyid,lr_id from t_loan_request order by lr_applyid,lr_id)r

        group by lr_aplyid)b

        where a.lr_applyid=b.lr_applyid

      )req

      on (lr.lr_id=req.lr_id)

      when matched then

        update set lr.seq=req.sno  

      

      插入数据sql如下:

      insert into t_loan_request(lr_id,lr_applyid,lr_requeststatus,seq)

      select seq_loan_request.nextval,'000123','0',(select count(1)+1 from t_loan_request where lr_applyid='000123')

      from dual 

      where not exists(select lr_id from t_loan_request where lr_requeststatus!='3' and lr_applyid='000123')

      上面的语句如果并发,lr_applyid+seq相同,数据库检查唯一性,最终导致只有一条记录入库成功

      

      或者使用merge插入语句

      merge into t_loan_request lr

      using (select count(1) cnt from t_loan_request where lr_requeststatus!='3' and lr_appplyid='000123')req

      on(req.cnt<1)

      when matched then

      insert (lr_id,lr_applyid,lr_requeststatus,seq)

      values(seq_loan_request.nextval,'000123','0',(select count(1)+1 from t_loan_request where lr_applyid='000123'))

      和上面的sql效果一样

  • sql改造,网上看的,但觉得不可靠

   INSERT INTO T_TABLE SELECT ?,?,?,?,? FROM DUAL WHERE NOT EXISTS (SELECT 1 FROM T_TABLE T WHERE T.FIELD1 = ? AND T.FIELD2 = ?)

   只是依靠这一条语句,如果并发,都符合where条件,同时入库插入成功

oracle--insert的更多相关文章

  1. Oracle INSERT ALL 语句介绍

    描述 Oracle INSERT ALL 语句用来用一个 INSERT 语句添加多行.该行可以只使用一个SQL命令插入到一个表或多个表. 语法 Oracle INSERT ALL 语法如下: INSE ...

  2. oracle Insert 一次插入多条记录

    oracle Insert 一次插入多条记录有两种方法: 1)Insert All Into table_name values ... insert all into table_name valu ...

  3. Oracle Insert 多行(转)

    1.一般的insert 操作. 使用语法insert into table_name[(column[,column...])] values (value[,value…])的insert语句,每条 ...

  4. oracle insert &字符插入问题

    例如执行一下语句: insert into NSRXT_SP (SP_ID, SP_TITLE, SP_DESC, SP_URL, SP_TYPE, SP_SUB_TYPE, ADD_TIME, CZ ...

  5. [Oracle] Insert All神奇

    无条件插入 Oracle中间insert all它指的是相同的数据组成不同的表.如果有需求现在:该t插入数据表t1,t2,假设你不知道insert all.您可以使用insert插入2次要,例如,见下 ...

  6. C# Oracle insert 中文乱码

    问题描述: 在PL SQL中insert 中文数据,显示不乱码,通过后台insert的中文数据,显示问号. 解决分三步: 1.Select userenv('language') from dual; ...

  7. oracle insert into 插入多组数据方法总结

    网上好多oracle 的文章,多是以oracle开头,内容确实其他sql,一幅气死人不偿命的嘴脸着实让人难受. 今天就更新点oracle 使用insert into插入数据的方式: 1.oracle ...

  8. oracle insert、append、parallel、随后查询的redo与磁盘读写

    SQL> set autotrace traceonly statistics; SQL> insert into big_table_dir_test1 select * from bi ...

  9. [Oracle] Insert All的妙用

    无条件的插入 Oracle中的insert all是指把同一批数据插入到不同的表中,假如如今有个需求:把t表中的数据分别插入t1,t2,假设你不知道insert all,你可能会使用insert插入2 ...

  10. ORACLE INSERT ALL 用法

    1INSERT ALL 1.1句法 multi_table_insert :: = conditional_insert_clause :: = 1.2multi_table_insert 在多表插入 ...

随机推荐

  1. 【现代程序设计】【homework-07】

    C++11 中值得关注的几大变化 1.Lambda 表达式 Lambda表达式来源于函数式编程,说白就了就是在使用的地方定义函数,有的语言叫“闭包”,如果 lambda 函数没有传回值(例如 void ...

  2. document.documentElement.clientHeight||document.documentElement.scrollHeight

    在我看<JavaScript高级程序设计>(第三版)的时候,在clientHeight和scrollHeight那部分把我弄糊涂了. 原书是这样写的:( //宽度同理,就不仔细描述了.) ...

  3. 5个Xcode开发调试技巧

    转自Joywii的博客,原文:Four Tips for Debugging in XCode Like a Bro    1.Enable NSZombie Objects(开启僵尸对象) Enab ...

  4. Linux df 命令用法示例

    介绍: Linux中df命令可以用来显示目前在Linux系统上的文件系统的磁盘使用情况统计.这些工具可以方便地知道哪些文件系统消耗多少内存.此外,如果被拾起,并且提供一个特定的文件名作为df命令的参数 ...

  5. osx升级到10.10后,用pod install报错最终解决办法

    转载自:http://blog.csdn.net/liuyujinglove/article/details/40582197 http://blog.csdn.net/dqjyong/article ...

  6. HDU 2874 Connections between cities (LCA)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2874 题意是给你n个点,m条边(无向),q个询问.接下来m行,每行两个点一个边权,而且这个图不能有环路 ...

  7. MVC4学习过程记录

    终于决定开始尝试Web开发,即是为了工作也是为了自己的兴趣,决定还是从MS的MVC4开始. 首先从Asp.Net MVC4入门指南这个系列开始学习(http://www.cnblogs.com/pow ...

  8. 深入了解 Dojo 的服务器推送技术

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html 内部邀请码:C8E245J (不写邀请码,没有现金送) 国 ...

  9. 当LinkButton无效时,光标不显示为手型

    在Flex组件LinkButton里,我们可以用useHandCursor属性来控制是否使用手型光标.现在我们要实现在LinkButton的enable=false时,useHandCursor=fa ...

  10. java中hashcode和equals的区别和联系

    HashSet和HashMap一直都是JDK中最常用的两个类,HashSet要求不能存储相同的对象,HashMap要求不能存储相同的键. 那么Java运行时环境是如何判断HashSet中相同对象.Ha ...