关于mybatis进行Update时,无法更新的问题

2017-02-14  传说中的情人节

问题描述:

今天进行mybatis进行update操作时候,发现代码一点错没有,但是数据库始终没有更新

详细代码:

	public Teacher findById(int tid){
		
		try{
			 teacher = sqlSession.selectOne("TeacherNamespace.findById", tid);
			sqlSession.commit();
			MybatisUtil.closeSqlSession();
		}catch(Exception e){
			sqlSession.rollback();
		}	
		return teacher;
	}
public void update1(Teacher teacher){
		SqlSession sqlSession = MybatisUtil.getSqlSession();
	
		try{
			
			int i = sqlSession.update("TeacherNamespace.upd", teacher);
			System.out.println(i);
			sqlSession.commit();
			MybatisUtil.closeSqlSession();
		}catch(Exception e){
			System.out.println(e);
			sqlSession.rollback();			
		}		
	}



结果发现:

我自己将SqlSession sqlSession = MybatisUtil.getSqlSession();这句代码sqlSession设置为了全局变量

更新操作根据ID更新,先找出ID对应的,再进行更新,因为全局变量,所以findById和update1是共用一个sqlSession,但是在执行第一个方法时,由于习惯自己把事务关闭了,所以无法进行Update



解决办法:

1.每个方法对应一个SqlSession对象,依旧是在每个方法的开头,写

Sqlsession sqlSession = MyBatisUtil.getSqlSession;


2.记住select方法不需要提交事务,也不需要关闭对象









你可能感兴趣的:(mybatis学习记录)