Mybatis配置insert时,插入数据失败

错误代码以下:java

@Test
    public void testInsertOne(){
        SqlSession sqlSession = MyBatisUtils.getSession();
        UserInfo userInfo = new UserInfo();
        userInfo.setNickname("sunny");
        userInfo.setPhoneNum("18936896033");
        sqlSession.insert("insertUser", userInfo);
        LOG.log(Level.INFO, "userId:"+userInfo.getId());
        sqlSession.close();
    }

缘由是会话没有被提交而是被回滚了,修改代码以下:sql

@Test
    public void testInsertOne(){
        SqlSession sqlSession = MyBatisUtils.getSession();
        UserInfo userInfo = new UserInfo();
        userInfo.setNickname("sunny");
        userInfo.setPhoneNum("18936896033");
        sqlSession.insert("insertUser", userInfo);
        sqlSession.commit(); //注意提交事物
        LOG.log(Level.INFO, "userId:"+userInfo.getId());
        sqlSession.close();
    }

源码解读:首先看看openSession的几种方式:ide

SqlSession openSession()
SqlSession openSession(boolean autoCommit)
SqlSession openSession(Connection connection)
SqlSession openSession(TransactionIsolationLevel level)
SqlSession openSession(ExecutorType execType,TransactionIsolationLevel level)
SqlSession openSession(ExecutorType execType)
SqlSession openSession(ExecutorType execType, boolean autoCommit)
SqlSession openSession(ExecutorType execType, Connection connection)

从地一个和第二个就可看出区别:get

openSession()会建立一个事物,可是不会自动提交源码

openSession(true)会建立一个事物,并自动提交it

openSession(Connection connection),不使用数据元配置,而是自定义的一个连接io

openSession(TransactionIsolationLevel level)事物的隔离级别:class

(NONE,READ_UNCOMMITTED,READ_COMMITTED,REPEA TABLE_READ,SERIALIZA BLE)test

openSession(ExecutorType execType):配置

  • ExecutorType.SIMPLE: 这个执行器类型不作特殊的事情。它为每一个语句的执行建立一个新的预处理语句。

  • ExecutorType.REUSE: 这个执行器类型会复用预处理语句。

  • ExecutorType.BATCH: 这个执行器会批量执行全部更新语句,若是 SELECT 在它们中间执行还会标定它们是 必须的,来保证一个简单并易于理解的行为。

相关文章
相关标签/搜索