MyBatis根据条件批量修改字段的方式

2023-05-16 0 2,957

目录

MyBatis根据条件批量修改字段

背景

给学生作业只要是对的都批量进行数据库的修改

代码以及注释

  • conttoller
@RestController
@RequestMapping(\"/work\")
public class WorkController {
    @Autowired
    private WorkService workService;
    
    @PutMapping(\"/examine\")
    public HttpResponse examine(Integer[] id) {
        Integer total = workService.examine(id);
        return HttpResponse.ok(\"共批改[ \"+total+\" ]条道题\",\"\");
    }
}
  • service
@Service
public class WorkService {
    @Autowired
    private WorkMapper workMapper;
    
    public Integer examine(Integer[] id) {
        return workMapper.examine(id);
    }
}
  • mapper
@Mapper
public interface WorkMapper {
    Integer examine(@Param(\"id\")Integer[] id);
}
  • xml
<!--根据id来批量修改WORK表里面的isEnable字段-->
<update id=\"examine\">
    UPDATE WORK SET isEnable=TRUE WHERE id IN
    <foreach collection=\"id\" item=\"id\" separator=\",\" open=\"(\" close=\")\">
        #{id}
    </foreach>
</update>
  • 工具类HttpResponse(此需求中无关紧要的类)
public class HttpResponse {
    private Integer status;
    private String message;
    private Object object;
    
    public static HttpResponse ok(String message) {
        return new HttpResponse(200, message, null);
    }
    
    public static HttpResponse ok(Object object) {
        return new HttpResponse(200, null, object);
    }
    
    public static HttpResponse ok(String message,Object object) {
        return new HttpResponse(200, message, object);
    }
    
    public static HttpResponse error(Integer status, String message) {
        return new HttpResponse(500, message, null);
    }
    
    public static HttpResponse error(String message) {
        return new HttpResponse(500, message, null);
    }
    
    public static HttpResponse error(String message,Object object) {
        return new HttpResponse(500, message, object);
    }
    
    
    protected HttpResponse() {
        super();
    }
    
    private HttpResponse(Integer status, String message, Object object) {
        super();
        this.status = status;
        this.message = message;
        this.object = object;
    }
    public Integer getStatus() {
        return status;
    }
    public void setStatus(Integer status) {
        this.status = status;
    }
    public String getMessage() {
        return message;
    }
    public void setMessage(String message) {
        this.message = message;
    }
    public Object getObject() {
        return object;
    }
    public void setObject(Object object) {
        this.object = object;
    }
}

重点:

如果mapper没加@Param("id")注解会报错找不到参数"id"

至此MyBatis根据id批量修改数据库的某字段需求完成!

MyBatis多条件批量修改

简单记录下

想要修改一张表,是联合主键,也就是where后两个以上条件才能唯一确定一条数据。

如果有唯一键,那么foreach中 用in就可以解决。

现在没办法用in,不然 A in (#{})and B in (#{})感觉成笛卡尔了。

简单点就是要实现执行多条语句。对update做循环。传入参数为 List,ATest类中字段A,B为联合主键,修改C的值

<update id=\"update\" parameterType=\"java.util.List\">
        <foreach collection=\"list\"  item=\"val\" separator=\";\" open=\"begin\" close=\";end;\">
            update table_ABC
            <set>
                <if test=\"val.C!= null\">C = #{val.C},</if>
            </set>
            where A=#{val.A} and B= #{val.B}
        </foreach>

    </update>

执行出来效果为:

begin 
update table_ABC set C = '2' where A = '1' and B= '1';
update table_ABC set C = '2' where A = '1' and B= '2';
update table_ABC set C = '4' where A = '3' and B= '2';
end;

这里使用的数据库为oracle,oracle执行认为begin和end之前为一条语句

当然,也可以用or 的形式拼接,不过还没测试。

网上查有的说是mysql数据库 mybatis一次执行一条语句。支持多条,可以MySQL连接数据库时,添加语句:“allowMultiQueries=true”

作用:

1.可以在sql语句后携带分号,实现多语句执行。

2.可以执行批处理,同时发出多个SQL语句。

总结

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

资源下载此资源下载价格为1小猪币,终身VIP免费,请先
由于本站资源来源于互联网,以研究交流为目的,所有仅供大家参考、学习,不存在任何商业目的与商业用途,如资源存在BUG以及其他任何问题,请自行解决,本站不提供技术服务! 由于资源为虚拟可复制性,下载后不予退积分和退款,谢谢您的支持!如遇到失效或错误的下载链接请联系客服QQ:442469558

:本文采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可, 转载请附上原文出处链接。
1、本站提供的源码不保证资源的完整性以及安全性,不附带任何技术服务!
2、本站提供的模板、软件工具等其他资源,均不包含技术服务,请大家谅解!
3、本站提供的资源仅供下载者参考学习,请勿用于任何商业用途,请24小时内删除!
4、如需商用,请购买正版,由于未及时购买正版发生的侵权行为,与本站无关。
5、本站部分资源存放于百度网盘或其他网盘中,请提前注册好百度网盘账号,下载安装百度网盘客户端或其他网盘客户端进行下载;
6、本站部分资源文件是经压缩后的,请下载后安装解压软件,推荐使用WinRAR和7-Zip解压软件。
7、如果本站提供的资源侵犯到了您的权益,请邮件联系: 442469558@qq.com 进行处理!

猪小侠源码-最新源码下载平台 Java教程 MyBatis根据条件批量修改字段的方式 http://www.20zxx.cn/705126/xuexijiaocheng/javajc.html

猪小侠源码,优质资源分享网

常见问题
  • 本站所有资源版权均属于原作者所有,均只能用于参考学习,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,建议提前注册好百度网盘账号,使用百度网盘客户端下载
查看详情

相关文章

官方客服团队

为您解决烦忧 - 24小时在线 专业服务