先是在日志里出现了
Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@38e46e4a]
看网上的博客,以为是XML中事务标签配错了,检查了好一阵子,发现并没有错。
接下来看日志中的报错
违反唯一建约束???
然后我去代码里查看,发现是代码逻辑写错了,
public ServerResponse<String> checkValid(String str, String type) { if (StringUtils.isNotBlank(type)) { if (Const.USERNAME.equals(type)) { int resultCount = userMapper.checkUsername(str); if (resultCount > 0) { return ServerResponse.createByErrorMessage("用户名已存在"); } } if (Const.EMAIL.equals(type)) { int resultCount = userMapper.checkEmail(str); if (resultCount > 0) { return ServerResponse.createByErrorMessage("Email已存在"); } } } else { return ServerResponse.createByErrorMessage("参数错误"); } return ServerResponse.createBySuccessMessage("校验成功"); }
if (resultCount > 0) { return ServerResponse.createByErrorMessage("用户名已存在"); }
本来是从数据找到一条数据,说明数据库里已经有该用户,不应该放行,我把条件写成了等于0,使这条重复的记录进入数据库,造成违反唯一键
Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@38e46e4a]
原文:https://www.cnblogs.com/figsprite/p/10913693.html