MyBatis批量操作_ORACLE

阅读前,请先阅读MyBatis批量操作_MySql

jdbc.properties

jdbc.driverClassName=oracle.jdbc.driver.OracleDriver
jdbc.url=jdbc:oracle:thin:@//127.0.0.1:1521/orcl
jdbc.username=mybatis
jdbc.password=mybatis

 在这里说说与mysql不同的,相同的就不再叙述了

 

Test方法

//通过list进行批量插入
	@Test
	public void batchInsertStudentWithListOracle(){
		  List<Student> list= new ArrayList<Student>();
		    for(int i = 2;i < 10;i++){
		        Student student = new Student();
		        student.setName("test" + i);
		        student.setId(i);
		        list.add(student);
		    }
		    int n=studentMapper.batchInsertStudentWithListOracle(list);
		    System.out.println("成功插入"+n+"条记录");
		    sqlSession.commit();
	}
	//分页批量插入
	@Test
	public void batchInsertStudentPageOracle(){
	    List<Student> list= new ArrayList<Student>();
	    for(int i = 0;i < 2000;i++){
	        Student student = new Student();
	        student.setName("test" + i);
	        student.setId(i);
	        list.add(student);
	    }
	    try {
			saveOracle(list);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
	
	private void saveOracle(List<Student> uidCodeList) throws Exception {
		SqlSession batchSqlSession = null;
		try {
			batchSqlSession =SqlSessionFactoryUtil.openSession();//获取批量方式的sqlsession		
			int batchCount = 1000;//每批commit的个数
			int batchLastIndex = batchCount - 1;//每批最后一个的下标
			for(int index = 0; index < uidCodeList.size()-1;){
				if(batchLastIndex > uidCodeList.size()-1){
					batchLastIndex = uidCodeList.size() - 1;
					batchSqlSession.insert("com.mybatis.mappers.StudentMapper.batchInsertStudentWithListOracle", uidCodeList.subList(index, batchLastIndex+1));
					batchSqlSession.commit();
					System.out.println("index:"+index+"     batchLastIndex:"+batchLastIndex);
					break;//数据插入完毕,退出循环
					
				}else{
					batchSqlSession.insert("com.mybatis.mappers.StudentMapper.batchInsertStudentWithListOracle", uidCodeList.subList(index, batchLastIndex+1));					                batchSqlSession.commit();
					System.out.println("index:"+index+"     batchLastIndex:"+batchLastIndex);
					index = batchLastIndex + 1;//设置下一批下标
					batchLastIndex = index + (batchCount - 1);						
				}				
			}						
		}finally{
			batchSqlSession.close();
		}		
	}
@Test
	public void batchUpdateStudentWithListOracle() {
		logger.info("更新学生(带条件)");
		List<Student> list = new ArrayList<Student>();
		list.add(new Student(5, "张三aa"));
		list.add(new Student(6, "李四aa"));
		int n = studentMapper.batchUpdateStudentWithListOracle(list);
		System.out.println("成功更新" + n + "条记录");
		sqlSession.commit();
	}
@Test
	public void batchDeleteStudentWithListOracle() {
		logger.info("通过IdList批量更新");
		List<Student> list = new ArrayList<Student>();
		list.add(new Student(12, null));
		list.add(new Student(13, null));
		int n = studentMapper.batchDeleteStudentWithListOracle(list);
		System.out.println("成功删除" + n + "条记录");
		sqlSession.commit();
	}

对应的Mapper

<insert id="batchInsertStudentWithListOracle" parameterType="List">
		
		insert into /*+append_values */ t_student(id,name)
		<foreach collection="list" item="item" index="index"
			separator="union all">
			select #{item.id}, #{item.name} from dual
		</foreach>
</insert>

<!-- open="begin" close=";end;" 要有 -->
<delete id="batchDeleteStudentWithListOracle" parameterType="java.util.List">
<span style="white-space:pre">	</span><foreach collection="list" item="item" index="index" open="begin" close=";end;" separator=";">
	<span style="white-space:pre">	</span>DELETE  FROM t_student	where id=#{item.id}
	</foreach>
	</delete>
<!-- open="begin" close=";end;" 要有 -->
<update id="batchUpdateStudentWithListOracle" parameterType="java.util.List">
	<foreach collection="list" item="item" index="index" open="begin" close=";end;" separator=";"  >
	UPDATE t_student
		<set>
			name=#{item.name}
		</set>
		where id=#{item.id}
	</foreach>
</update>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

有恒则成

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

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

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

打赏作者

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

抵扣说明:

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

余额充值