2 qin528032307 qin528032307 于 2017.09.15 09:41 提问

MyBatis中怎么使用拦截器记录操作之前和之后的数据?

在ssm框架搭建的web项目中,想在每次操作数据库之前(增、改、删),把原来的数据和操作之后的数据保存。怎么实现呢?
例如:数据库有一条记录id:1,name:tom,把其修改为id:1,name:jack,怎么通过拦截器的方式拿到这两条数据?

3个回答

qq_38849721
qq_38849721   2017.09.15 09:49

我看的不是很明白,不过看你这个意思应该是想在完成sql后提交,也就是commit,在mybatis有一个方法 sqlSession.commit();

qin528032307
qin528032307 数据库有一条记录id:1,name:tom,把其修改为id:1,name:jack,怎么通过拦截器的方式拿到这两条数据?
2 个月之前 回复
u012743772
u012743772   2017.09.15 10:39

你每次操作数据之前先查询,把操作前的数据先放本地缓存就可以了,然后修改。。。

qq_33727653
qq_33727653   2017.09.15 10:46

为什么要用拦截器做? 而且楼主打算把原来的数据存在什么地方?单纯就保存新数据和老数据而言,用数据库触发器就行,但是至于为啥要拦截器拿着俩数据呢? 在保存之前 新数据和老数据不都有了?

Csdn user default icon
上传中...
上传图片
插入图片