MybatisPlus空字段无法修改 MybatisPlus修改时空字段无法修改的解决方案

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

MybatisPlus空字段无法修改 MybatisPlus修改时空字段无法修改的解决方案

鲨鱼辣椒灬   2021-09-01 我要评论
想了解MybatisPlus修改时空字段无法修改的解决方案的相关内容吗,鲨鱼辣椒灬在本文为您仔细讲解MybatisPlus空字段无法修改的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:MybatisPlus修改,空字段修改,MybatisPlus空字段,下面大家一起来学习吧。

MybatisPlus空字段无法修改

在这里插入图片描述

点开修改

在这里插入图片描述

数据为空时,点击确定,可列表出现的数据还是为原来的数据

查看后台的打印输出,发现没有更新的这2个字段

这个时候,在实体类中加入

在这里插入图片描述

这行注释的意思是

在属性执行修改时,将自动填充一个值(默认为null),即将字段修改为空,而不是不做修改。

Mybatis-Plus修改指定字段

核心代码

/**
	 * 修改密码(只能修改自己的密码)
	 * 
	 * @author zhangxuewei
	 * @param userID
	 * @param password
	 * @param session
	 * @return
	 */
	@ResponseBody
	@RequestMapping(value = "/updateUserPWD", method = RequestMethod.POST)
	public ResultCode updateUserPWD(@RequestParam(value = "password_old") String password,
			@RequestParam(value = "password_new") String newpassword, HttpSession session) {
		logger.info("updateUserPWD ...........");
		User user1 = (User) session.getAttribute("sessionUser");
		ResultCode res = new ResultCode();
		EntityWrapper<User> ew = new EntityWrapper<>();
		ew.eq("user_name", user1.getUserName());
		User user2=  userService.selectOne(ew);
		if(user2.getPassWord().equals(AIAppUtils.encrypt(password))) {
			if (StringUtils.isNotBlank(password) && StringUtils.isNotBlank(newpassword)) {
				String setSql = "pass_word = " + "'" + AIAppUtils.encrypt(newpassword) + "'";
				EntityWrapper<User> ew1 = new EntityWrapper<>();
 
				ew1.eq("user_id", user1.getUserID());
 
				try {
					userService.updateForSet(setSql, ew1);
					session.removeAttribute("sessionUser");
					res.setCode(0);
					
				} catch (Exception e) {
					// TODO: handle exception
					res.setCode(1);
				}
			} else {
				// 参数不能为空
				res.setCode(1);
				res.setMsg("参数不能为空");
			}
 
		}else {
			res.setCode(1);
			res.setMsg("原始密码不正确!");
		}
		
		return res;
	}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们