oracle--insert
常规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的更多相关文章
- Oracle INSERT ALL 语句介绍
描述 Oracle INSERT ALL 语句用来用一个 INSERT 语句添加多行.该行可以只使用一个SQL命令插入到一个表或多个表. 语法 Oracle INSERT ALL 语法如下: INSE ...
- oracle Insert 一次插入多条记录
oracle Insert 一次插入多条记录有两种方法: 1)Insert All Into table_name values ... insert all into table_name valu ...
- Oracle Insert 多行(转)
1.一般的insert 操作. 使用语法insert into table_name[(column[,column...])] values (value[,value…])的insert语句,每条 ...
- oracle insert &字符插入问题
例如执行一下语句: insert into NSRXT_SP (SP_ID, SP_TITLE, SP_DESC, SP_URL, SP_TYPE, SP_SUB_TYPE, ADD_TIME, CZ ...
- [Oracle] Insert All神奇
无条件插入 Oracle中间insert all它指的是相同的数据组成不同的表.如果有需求现在:该t插入数据表t1,t2,假设你不知道insert all.您可以使用insert插入2次要,例如,见下 ...
- C# Oracle insert 中文乱码
问题描述: 在PL SQL中insert 中文数据,显示不乱码,通过后台insert的中文数据,显示问号. 解决分三步: 1.Select userenv('language') from dual; ...
- oracle insert into 插入多组数据方法总结
网上好多oracle 的文章,多是以oracle开头,内容确实其他sql,一幅气死人不偿命的嘴脸着实让人难受. 今天就更新点oracle 使用insert into插入数据的方式: 1.oracle ...
- oracle insert、append、parallel、随后查询的redo与磁盘读写
SQL> set autotrace traceonly statistics; SQL> insert into big_table_dir_test1 select * from bi ...
- [Oracle] Insert All的妙用
无条件的插入 Oracle中的insert all是指把同一批数据插入到不同的表中,假如如今有个需求:把t表中的数据分别插入t1,t2,假设你不知道insert all,你可能会使用insert插入2 ...
- ORACLE INSERT ALL 用法
1INSERT ALL 1.1句法 multi_table_insert :: = conditional_insert_clause :: = 1.2multi_table_insert 在多表插入 ...
随机推荐
- UIImageView旋转任意角度
-(UIImageView *) makeRotation:(UIImageView *)image speedX:(float)X speedY:(float)Y { // 头文件中需要定义 ...
- C++获取系统的Mac地址
C++获取系统的Mac地址,加上libnetapi32.a #include <windows.h> #include <stdlib.h> #include <stdi ...
- HDU 5726 GCD (RMQ + 二分)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5726 给你n个数,q个询问,每个询问问你有多少对l r的gcd(a[l] , ... , a[r]) ...
- C++中动态申请二维数组并释放方法
C/C++中动态开辟一维.二维数组是非常常用的,以前没记住,做题时怎么也想不起来,现在好好整理一下. C++中有三种方法来动态申请多维数组 (1)C中的malloc/free (2)C++中的new/ ...
- ElasticSearch+Springboot实际应用:索引同步建设,搜索过程
1.介绍 springboot框架,众多自动化的部署和约定配置,造成了springboot的着手麻烦,熟练后可以快速快捷进行开发,常用作快捷开发的java底层框架.各位看官都是大神,自行体会. ...
- Thinkphp框架 -- 短信接口验证码
我用的是一款名叫 短信宝 的应用,新注册的用户可以免费3条测试短信,发现一个BUG,同个手机可以无限注册,自己玩玩还是可以的. 里面的短信接口代码什么信息都没有,感觉看得不是很明白,自己测试了一遍,可 ...
- ALV的报表对用户定义格式的控制(ALV I_SAVE)
很多ALV的报表都需要手动的进行设置格式以使数据看上去更有意义和条理,如果每次进来都重新操作一遍是很烦人的,所以SAP有提供了一个保存格式的功能,保存格式可以是 '缺省设置' 和 '特定用户' 两种 ...
- Install eclipse groovy plugin
http://dist.springsource.org/release/GRECLIPSE/e4.4/
- 【转】2013年中国IT业10大公司
转自:http://www.chinaz.com/news/2013/1217/331446.shtml?zyy 1.最得志的公司:小米 在2013年,再没有一家公司像小米这样志得意满,即便看看所有的 ...
- mysql中查询"_"这种特殊字符
http://www.w3school.com.cn/sql/sql_wildcards.asp SQL 通配符 在搜索数据库中的数据时,SQL 通配符可以替代一个或多个字符. SQL 通配符必须与 ...