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方法不需要提交事务,也不需要关闭对象