MyBatis 批量修改(update)数据表某字段

  • studentMapper.xml 文件内容
<update id="updateName">
       update student set grade = #{newGrade}, course = #{newCourse}
       where stuID in (
       <foreach collection="idList" item="item" index="index" open="" close="" separator=",">
           #{item}
       </foreach>
       )
   </update>
  • studentMapper 接口 interface(继承了baseMapper)文件内容,idList 需是 list 类型,不能是逗号分割的 String
	int updateInfo(@Param("idList") List idList, @Param("newGrade") String newGrade, @Param("newCourse") String newCourse);
  • studentService 接口 interface 文件内容
	boolean updateInfo(List idList, String newGrade, String newCourse);
  • studentServiceImpl java文件内容
@Override
	public boolean updateInfo(List idList, String newGrade, String newCourse) {
		int result = baseMapper.updateInfo(idList, newGrade, newCourse);
		return result > 0;
	}
  • studentcontroller java 文件内容
	@PostMapping("/updateInfo")
	@ApiOperationSupport
	@Transactional(rollbackFor = Exception.class)
	@ApiOperation(value = "批量更改学生信息", notes = "传入需要修改的学生id,grade,course")
	public R<Object> updateInfo(@RequestBody Map<String,Object> map) {
		if (!ObjectUtils.isEmpty(map.get("idList"))) {
			// 更新的执行结果(true:成功,false:失败)
			boolean result = false;
			// 将接收到的学生ids 转为 list
			List idList= Arrays.asList(String.valueOf(map.get("idList")).split(","));
			result = studentService.updateInfo(idList, String.valueOf(map.get("newGrade")), String.valueOf(map.get("newCourse")));
			if (!result) {
				throw new ServiceException("更新失败!");
			}
		}
		return R.status(true);
	}
  • 前端传参 js文件
export const updateInfo= (param) => {
  return request({
    url: '/api/collage/student/updateInfo',
    method: 'post',
    data: param
  })
}
  • 前端 vue 文件传参的定义
var param = {
		idList:this.stuIds,
        newGrade:this.grade,
        newCourse:this.course,
      }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值