oracle应用之批量新增更新数据

本博客介绍一下Oracle批量新增数据和更新数据的sql写法,业务场景是这样的,往一张关联表里批量新增更新数据,然后,下面介绍一下批量新增和更新的写法:

批量新增数据
对于批量新增数据,介绍两种方法

(1)命令窗口执行的
一种需要在命令窗口执行的,Oracle数据库可以使用sqlplus或者plsql developer客户端软件

可以使用sqlplus工具登录,进入数据库

sqlplus / as sysdba

查看用户,可以用命令

show parameter db_name

plsql developer也可以使用,登录之后,选择文件(File)->新建(New)->命令窗口(Command Window)
假如要往表格t里写1000条数据,可以用如下批处理命令:

begin 
	for i in 1 .. 1000
	loop
		execute immediate
		'insert into t values('|| i ||')';
	end loop;
	commit;
end;

ps:这个commit提交事务,放的位置也是有区别的,具体可以参考我之前的博客,Oracle体系结构学习笔记里面有涉及到

(2) SQL窗口执行的
然后介绍sql窗口执行的方法,因为命令窗口执行有时候觉得不太便利,所以可以使用sql窗口的方法,语法大致为:

insert into [表格名称](字段名称1,字段名称2,...) [查询SQL]

给个例子,sys_guid()生成uuid数据,sysdate获取当前时间,然后批量写数据,根据查询sql来

insert into t_stuff_dir_related
  (seq, dir_seq, create_date, create_man, stuff_id, t_item)
  select sys_guid(),
         'uuidss',
         sysdate,
         'admin',
         b.rs_id,
         a.t_item
    from t_itm_define a
  where a.is_valid =1

批量更新数据

对于批量更新的和批量新增方法类型,同样可以用命令窗口和sql窗口两种方法

(1)命令窗口执行的

同样可以用如下批处理命令:

begin 
	for i in 1 .. 1000
	loop
		execute immediate
		'${更新SQL}';
	end loop;
	commit;
end;

(1)SQL窗口执行的

批量更新加了where条件就可以

 update t_itm_rcv_stuff stuff
    set stuff.dir_seq = '${目录SEQ}', stuff.dir_name = '${目录名称}'
  where stuff.t_item in
        (select a.t_item
           from t_itm_define a)

阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 针对Oracle批量插入和更新,可以使用以下两种方法: 1. 使用PL/SQL语句进行批量插入和更新。可以通过编写存储过程或使用FORALL语句来实现。通过将多条数据放入数组中,然后使用FORALL语句批量执行插入或更新操作,可以减少与数据库的通信次数,提高性能。此方法适用于需要处理大量数据的场景。 示例代码如下: ``` DECLARE TYPE emp_type IS TABLE OF employees%ROWTYPE; emp_data emp_type; BEGIN -- 将数据保存到数组中 emp_data := emp_type( employees_rec(1001, 'John', 'Smith', 'Manager', 5000), employees_rec(1002, 'Amy', 'Johnson', 'Sales Rep', 3000), employees_rec(1003, 'David', 'Brown', 'Engineer', 4000) ); -- 批量插入数据 FORALL i IN 1..emp_data.COUNT INSERT INTO employees VALUES emp_data(i); -- 批量更新数据 FORALL i IN 1..emp_data.COUNT UPDATE employees SET salary = emp_data(i).salary WHERE employee_id = emp_data(i).employee_id; COMMIT; END; / ``` 2. 使用INSERT ALL和MERGE INTO语句进行批量插入和更新。INSERT ALL语句可以一次性插入多条数据,而MERGE INTO语句可以同时处理插入和更新操作,根据指定的条件进行判断并执行相应的操作。这些语句提供了一种更简洁和高效的方式来进行批量操作。 示例代码如下: ``` -- 批量插入数据 INSERT ALL INTO employees (employee_id, first_name, last_name, title, salary) VALUES (1001, 'John', 'Smith', 'Manager', 5000) INTO employees (employee_id, first_name, last_name, title, salary) VALUES (1002, 'Amy', 'Johnson', 'Sales Rep', 3000) INTO employees (employee_id, first_name, last_name, title, salary) VALUES (1003, 'David', 'Brown', 'Engineer', 4000) SELECT * FROM DUAL; -- 批量更新数据 MERGE INTO employees e USING ( SELECT 1001 AS employee_id, 5500 AS salary FROM DUAL UNION ALL SELECT 1003, 4200 FROM DUAL ) d ON (e.employee_id = d.employee_id) WHEN MATCHED THEN UPDATE SET e.salary = d.salary; COMMIT; ``` 以上是针对Oracle批量插入和更新的两种常用方法,可以根据实际需求选择最适合的方法来提高数据库操作效率。 ### 回答2: Oracle数据库中,针对批量插入和更新操作,可以采用以下的几种方法。 首先,可以使用PL/SQL语言编写存储过程或函数来实现批量插入和更新。通过循环结构,可以一次性插入或更新多条记录,从而提高效率。同时,还可以利用FORALL语句来进行批量操作,它可以将多个DML语句的执行集中在一起,减少了与数据库之间的交互次数,提高了性能。 其次,Oracle提供了批量绑定技术,可以利用绑定变量来实现批量插入和更新。这种方法通过使用数组来绑定变量,可以将多个数据项一次性传递给数据库,从而减少了数据库和应用程序之间的通信开销。 另外,Oracle还提供了外部表(External Table)的功能,可以通过将外部数据文件映射到数据库表中,实现批量数据的插入和更新。通过这种方式,可以直接将大量数据文件加载到数据库中,大大提高了数据导入和更新的速度。 另外,对于大规模的数据插入和更新操作,还可以考虑使用并行处理(Parallel Processing)技术。Oracle数据库支持并行执行DML语句,可以利用多个CPU来实现批量插入和更新,从而提高性能。 总之,针对Oracle数据库的批量插入和更新操作,可以结合使用PL/SQL语言、批量绑定技术、外部表和并行处理等多种方法来实现,以提高效率和性能。 ### 回答3: 针对Oracle批量插入和更新功能,我们可以通过以下两种方法来实现: 1. 使用INSERT ALL和MERGE INTO语句实现批量插入和更新。INSERT ALL语句可以将多个插入语句合并为一个语句,从而提高插入效率。MERGE INTO语句可以根据某些条件进行插入和更新操作。我们可以在一个语句中同时执行插入和更新操作,从而减少与数据库的通信次数,提高性能。 例如,下面是使用INSERT ALL和MERGE INTO语句实现批量插入和更新的示例代码: ``` INSERT ALL INTO table_name (column1, column2) VALUES ('value1', 'value2') INTO table_name (column1, column2) VALUES ('value3', 'value4') ... SELECT 1 FROM DUAL; MERGE INTO table_name USING dual ON (condition) WHEN MATCHED THEN UPDATE SET column1 = 'new_value1', column2 = 'new_value2' WHEN NOT MATCHED THEN INSERT (column1, column2) VALUES ('new_value1', 'new_value2'); ``` 2. 使用批处理功能实现批量插入和更新。使用Oracle的批处理功能可以减少与数据库的通信次数,从而提高性能。我们可以在应用程序中使用PreparedStatement对象,并通过调用其addBatch()方法来将多个插入或更新操作添加到批处理中,最后通过调用executeBatch()方法来执行批处理。 例如,下面是使用批处理功能实现批量插入和更新的示例代码: ``` Connection conn = DriverManager.getConnection(url, username, password); PreparedStatement pstmt = conn.prepareStatement("INSERT INTO table_name (column1, column2) VALUES (?, ?)"); pstmt.setString(1, "value1"); pstmt.setString(2, "value2"); pstmt.addBatch(); pstmt.setString(1, "value3"); pstmt.setString(2, "value4"); pstmt.addBatch(); int[] result = pstmt.executeBatch(); conn.commit(); pstmt.close(); conn.close(); ``` 以上就是针对Oracle批量插入和更新的简要说明。使用这些方法可以有效地提高插入和更新操作的性能和效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

smileNicky

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值