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

本文记录了一次使用MyBatis进行数据库更新操作时遇到的问题:代码无误但数据库未更新。通过分析发现,原因是将SqlSession设为全局变量并在不同方法间复用,导致其中一个方法中手动关闭了事务,从而使后续的更新操作无法执行。文章提供了两种解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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









评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值