04 CRUD

这篇博客详细介绍了MyBatisPlus的CRUD操作,包括Mapper和Service层的接口,如insert、deleteById、updateById、selectById等,同时提到了分页查询和条件构造器的使用。
摘要由CSDN通过智能技术生成

1. Mapper CRUD 接口

  • 通用 CRUD 封装BaseMapper接口,为 Mybatis-Plus 启动时自动解析实体表关系映射转换为 Mybatis 内部对象注入容器
  • 泛型 T 为任意实体对象
  • 参数 Serializable 为任意类型主键 Mybatis-Plus 不推荐使用复合主键约定每一张表都有自己的唯一 id 主键
  • 对象 Wrapper 为 条件构造器

添加

1. insert
/**
 * <p>
 * 插入一条记录
 * </p>
 *
 * @param entity 实体对象
 * @return 插入成功记录数
 */
int insert(T entity);

insert() 方法在插入的时候,会根据实体类的每个属性进行非空判断,只有非空的属性对应字段才会出现到SQL语句中。
insertAllColumn() 不管属性是否为空,都会全部在SQL语句中。3.0以前;

删除

2. deleteById
/**
 * <p>
 * 根据 ID 删除
 * </p>
 *
 * @param id 主键ID
 * @return 删除成功记录数
 */
int deleteById(Serializable id);

范例

Integer result = userMapper.deleteById(1045130111860420610L);

System.out.println("数据库受影响行数:" + result);
3. deleteByMap
/**
 * <p>
 * 根据 columnMap 条件,删除记录
 * </p>
 *
 * @param columnMap 表字段 map 对象
 * @return 删除成功记录数
 */
int deleteByMap(@Param(Constants.COLUMN_MAP) Map<String, Object> columnMap);

条件是通过 AND 链接

范例

Map<String, Object> columnMap = new HashMap<>();
columnMap.put("name", "小花123");
columnMap.put("age", "20");

Integer result = userMapper.deleteByMap(columnMap);
System.out.println(result);
4. delete
/**
 * <p>
 * 根据 entity 条件,删除记录
 * </p>
 *
 * @param queryWrapper 实体对象封装操作类(可以为 null)
 * @return 删除成功记录数
 */
int delete(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper);
5. deleteBatchIds
/**
 * <p>
 * 删除(根据ID 批量删除)
 * </p>
 *
 * @param idList 主键ID列表(不能为 null 以及 empty)
 * @return 删除成功记录数
 */
int deleteBatchIds(@Param(Constants.COLLECTION) Collection<? extends Serializable> idList);

范例

List<Integer> idList = new ArrayList<>();

idList.add(1);
idList.add(4)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值