MyBatis Plus Mapper CRUD接口测试方式

 更新时间:2024年09月20日 09:06:27   作者:小大宇  
在数据库管理系统中,插入记录是添加新数据条目,而删除操作包括根据主键ID单条删除和批量删除,也可以基于特定条件进行删除,删除操作的SQL语句是通过键值对在Map中拼接而成,如delete from 表 where key1=value1 AND key2=value2

MyBatis Plus Mapper CRUD接口测试

插入

插入一条记录

int insert(T entity);

删除

根据主键ID删除,主键ID支持String、Number类型

int deleteById(Serializable id);

根据主键ID批量删除

int deleteBatchIds(Collection<? extends Serializable> idList);

根据条件进行删除。原理为SQL语句拼接,因此Map中需要传输数据库字段列

实质为 delete from 表 where 【key1 = value1】 AND 【key2 = value2】

【key1-value1】【key2-value2】为Map的键值对

int deleteByMap(Map<String, Object> columnMap);

更新

根据ID更新。null值忽略。

        Employee employee = new Employee();
        employee.setId(7);
        employee.setLastName("a");
        employee.setAge(23);
        employee.setEmail(null);
        employee.setGender(null);
        mapper.updateById(employee);

 UPDATE tb_employee SET last_name='a', age=23
 WHERE id=7;

根据条件更新,null值忽略。

        Employee employee = new Employee();
        employee.setId(7L);
        employee.setLastName("c");
        //这里设置的null,就是说不操作email字段
        employee.setEmail(null);
        employee.setGender(null);
        employee.setAge(23);
        mapper.update(employee, new UpdateWrapper<Employee>().lambda()
                .eq(Employee::getId, 7)
        );

 UPDATE tb_employee SET last_name='c', age=23
 WHERE (id = 7);

定制置空。

        Employee employee = new Employee();
        employee.setId(7L);
        employee.setLastName("c");
        //这里设置的null,就是说不操作email字段
        employee.setEmail(null);
        employee.setGender(null);
        employee.setAge(23);
        mapper.update(employee, new UpdateWrapper<Employee>().lambda()
                .eq(Employee::getId, 7)
                //这里可以定制置空SQL
                .set(Employee::getEmail,null)
                .set(Employee::getGender,"")
        );

 UPDATE tb_employee SET last_name='c', age=23, email=null,gender=''
 WHERE (id = 7);

总结

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

相关文章

  • Java如何获取主机的基本信息详解

    Java如何获取主机的基本信息详解

    最近遇到一个工作需求,上网查了一下怎样在Java中获取本机的ip和主机名,所以下面这篇文章主要给大家介绍了关于Java如何获取主机的基本信息,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2021-12-12
  • 详细谈谈Java中long和double的原子性

    详细谈谈Java中long和double的原子性

    原子性是指一个操作或多个操作要么全部执行,且执行的过程不会被任何因素打断,要么就都不执行,下面这篇文章主要给大家介绍了关于Java中long和double原子性的相关资料,需要的朋友可以参考下
    2021-08-08
  • Java中的"找不到符号"错误解决办法

    Java中的"找不到符号"错误解决办法

    开发中遇到一个问题,当我用idea开发工具将新的项目代码从GitLab上面拉取下来,所有的Maven依赖也导入成功,然后启动项目,结果报错:java:找不到符号,这篇文章主要给大家介绍了关于Java中"找不到符号"错误的解决办法,需要的朋友可以参考下
    2023-10-10
  • Spring @Conditional注解讲解及示例详解

    Spring @Conditional注解讲解及示例详解

    这篇文章主要介绍了Spring @Conditional注解讲解及示例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • 解决Spring或SpringBoot开启事务以后无法返回自增主键的问题

    解决Spring或SpringBoot开启事务以后无法返回自增主键的问题

    这篇文章主要介绍了解决Spring或SpringBoot开启事务以后无法返回自增主键的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • 使用MUI框架构建App请求http接口实例代码

    使用MUI框架构建App请求http接口实例代码

    下面小编就为大家分享一篇使用MUI框架构建App请求http接口实例代码,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • Springmvc获取前台请求数据过程解析

    Springmvc获取前台请求数据过程解析

    这篇文章主要介绍了Springmvc获取前台请求数据过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-07-07
  • 解决IDEA项目project包目录消失的问题

    解决IDEA项目project包目录消失的问题

    这篇文章主要介绍了解决IDEA项目project包目录消失的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • Java比较两个对象大小的三种方法详解

    Java比较两个对象大小的三种方法详解

    在优先级队列中插入的元素必须能比较大小,如果不能比较大小,如插入两个学生类型的元素,会报ClassCastException异常。本文就为大家总结了Java比较两个对象大小的三种方法,需要的可以参考一下
    2022-07-07
  • Java模版引擎Freemarker

    Java模版引擎Freemarker

    FreeMarker是一个模板引擎,一个基于模板生成文本输出的通用工具,使用纯Java编写 FreeMarker被设计用来生成HTML Web页面,特别是基于MVC模式的应用程序
    2016-04-04

最新评论