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









  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值