zoukankan      html  css  js  c++  java
  • mybatis 使用sqlSessionFactory实现批量操作

    sqlSessionFactory实现批量提交的java,但无法返回受影响数量。

     1 public int updateBatch(List<Object> list){
     2         if(list ==null || list.size() <= 0){
     3             return -1;
     4         }
     5         SqlSessionFactory sqlSessionFactory = SpringContextUtil.getBean("sqlSessionFactory");
     6         SqlSession sqlSession = null;
     7         try {
     8             sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH,false);
     9             Mapper mapper = sqlSession.getMapper(Mapper.class);
    10             int batchCount = 1000;//提交数量,到达这个数量就提交
    11             for (int index = 0; index < list.size(); index++) {
    12                 Object obj = list.get(index);
    13                 mapper.updateInfo(obj);
    14                 if(index != 0 && index%batchCount == 0){
    15                     sqlSession.commit();
    16                 }                    
    17             }
    18             sqlSession.commit();
    19             return 0;
    20         }catch (Exception e){
    21             sqlSession.rollback();
    22             return -2;
    23         }finally {
    24             if(sqlSession != null){
    25                 sqlSession.close();
    26             }
    27         }
    28         
    29 }
    @Component
    public class SpringContextUtil implements ApplicationContextAware{
    
        private static ApplicationContext applicationContext;
    
        @Override
        public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
            SpringContextUtil.applicationContext = applicationContext;
        }
    
        public static ApplicationContext getApplicationContext(){
            return applicationContext;
        }
    
        public static Object getBean(Class T){
            try {
                return applicationContext.getBean(T);
            }catch (BeansException e){
                return null;
            }
        }
    
        public static Object getBean(String name){
            try {
                return applicationContext.getBean(name);
            }catch (BeansException e){
                return null;
            }
        }
    }
  • 相关阅读:
    手把手教你用Python模拟登录淘宝
    数据库链接方式ORM
    ubuntu命令
    django项目不能运行解决方法
    区别比较 match和search
    redis持久化RDB与AOF
    python基础数据类型
    python基础二
    Python中将一个对象倒序输出的4种方法
    python基础数据类型补充以及编码的进阶
  • 原文地址:https://www.cnblogs.com/lgjava/p/11263035.html
Copyright © 2011-2022 走看看