mybatis-plus Wrapper 条件构造器 updateForSet更新

官方文档:https://baomidou.gitee.io/mybatis-plus-doc/#/wrapper

实体包装器,用于处理 sql 拼接,排序,实体参数查询等!

补充说明: 使用的是数据库字段,不是Java属性!

实体包装器 EntityWrapper 继承 Wrapper

简单示例

  • 翻页查询
public Page<T> selectPage(Page<T> page, EntityWrapper<T> entityWrapper) {
  if (null != entityWrapper) {
      entityWrapper.orderBy(page.getOrderByField(), page.isAsc());
  }
  page.setRecords(baseMapper.selectPage(page, entityWrapper));
  return page;
}
  • 拼接 sql 方式 一
@Test
public void testTSQL11() {
    /*
     * 实体带查询使用方法  输出看结果
     */
    EntityWrapper<User> ew = new EntityWrapper<User>();
    ew.setEntity(new User(1));
    ew.where("user_name={0}", "'zhangsan'").and("id=1")
            .orNew("user_status={0}", "0").or("status=1")
            .notLike("user_nickname", "notvalue")
            .andNew("new=xx").like("hhh", "ddd")
            .andNew("pwd=11").isNotNull("n1,n2").isNull("n3")
            .groupBy("x1").groupBy("x2,x3")
            .having("x1=11").having("x3=433")
            .orderBy("dd").orderBy("d1,d2");
    System.out.println(ew.getSqlSegment());
}
  •  
  • 括号拼接
    
    .isNull("removor").andNew("idCard="+ idCard+" or phone="+ phone)
    
    sql
    
    (removor IS NULL) AND (idCard=666 or phone=15866958266) 

     

  • 拼接 sql 方式 二
int buyCount = selectCount(Condition.create()
                .setSqlSelect("sum(quantity)")
                .isNull("order_id")
                .eq("user_id", 1)
                .eq("type", 1)
                .in("status", new Integer[]{0, 1})
                .eq("product_id", 1)
                .between("created_time", startDate, currentDate)
                .eq("weal", 1));

更新:updateForSet根据条件更新字段

.updateForSet("hits=hits+1", new EntityWrapper<T>().eq("id", id));
  • 自定义 SQL 方法如何使用 Wrapper

mapper java 接口方法

List<User> selectMyPage(RowBounds rowBounds, @Param("ew") Wrapper<T> wrapper);

mapper xml 定义

<select id="selectMyPage" resultType="User">
  SELECT * FROM user 
  <where>
  ${ew.sqlSegment}
  </where>
</select>

关于 ${ew.sqlSegment} 使用了 $ 不要误以为就会被 sql 注入,请放心使用 mp 内部对 wrapper 进行了字符转义处理!

条件参数说明

查询方式说明
setSqlSelect设置 SELECT 查询字段
whereWHERE 语句,拼接 + WHERE 条件
andAND 语句,拼接 + AND 字段=值
andNewAND 语句,拼接 + AND (字段=值)
orOR 语句,拼接 + OR 字段=值
orNewOR 语句,拼接 + OR (字段=值)
eq等于=
allEq基于 map 内容等于=
ne不等于<>
gt大于>
ge大于等于>=
lt小于<
le小于等于<=
like模糊查询 LIKE
notLike模糊查询 NOT LIKE
inIN 查询
notInNOT IN 查询
isNullNULL 值查询
isNotNullIS NOT NULL
groupBy分组 GROUP BY
havingHAVING 关键词
orderBy排序 ORDER BY
orderAscASC 排序 ORDER BY
orderDescDESC 排序 ORDER BY
existsEXISTS 条件语句
notExistsNOT EXISTS 条件语句
betweenBETWEEN 条件语句
notBetweenNOT BETWEEN 条件语句
addFilter自由拼接 SQL
last拼接在最后,例如:last("LIMIT 1")

注意! xxNew 都是另起 ( ... ) 括号包裹。

### 回答1: mapper.java和mapper.xml是MyBatis框架中的两个重要文件。 mapper.java是一个Java接口,用于定义数据库操作的方法。在mapper.java中,我们可以定义增删改查等操作的方法,并且可以通过注解或XML文件来映射SQL语句。 mapper.xml是一个XML文件,用于定义SQL语句和参数映射。在mapper.xml中,我们可以定义SQL语句,以及SQL语句中的参数和返回值的映射关系。同时,我们也可以在mapper.xml中定义一些复杂的SQL语句,如多表查询、分页查询等。 在MyBatis框架中,mapper.java和mapper.xml是一一对应的,即每个mapper.java对应一个mapper.xml文件。这种设计可以使代码更加清晰,易于维护。 ### 回答2: mapper.java和mapper.xml都是MyBatis框架中的重要组成部分。其中mapper.java是MyBatis框架中定义DAO的接口,而mapper.xml是DAO接口的具体实现。 mapper.java是DAO层的接口,定义了基本的业务操作方法,例如查询、插入、更新、删除等。它主要由两部分组成:一是声明DAO接口的名称和方法,二是声明DAO接口方法的参数和返回值类型。 mapper.xml则是为DAO接口提供具体的实现。mapper.xml中定义了SQL语句,用于访问数据库。它包含SQL语句、参数映射、结果映射等信息。在MyBatis中,mapper.xml文件中的SQL语句是可以动态生成的,这使得MyBatis易于开发。 映射器的使用可以实现业务逻辑与数据访问之间的解耦。它们提供了一个清晰的接口,使开发人员能够快速实现数据访问逻辑。在使用MyBatis框架时,mapper.java和mapper.xml通常是组合起来使用的,其中mapper.java提供的接口方法将会调用mapper.xml中定义的SQL语句来实现具体业务逻辑。这种实现方式非常灵活,并且易于维护。 ### 回答3: Mapper.java和Mapper.xml是MyBatis框架描述SQL语句和Java类之间映射关系的两种方式。 Mapper.java是使用Java代码来描述SQL语句和对应的参数、返回值类型。Mapper.java中的方法对应SQL语句,参数是该语句需要传递的参数,返回值是SQL语句执行结果。Mapper.java可以使得编写Java程序更加直观,同时也可以静态类型检查,减少代码错误。 Mapper.xml则是使用XML文件来描述SQL语句和Java类之间的映射关系。Mapper.xml中包含了SQL语句、参数类型、返回值类型等信息,而且还可以使用一些特殊标签来处理SQL语句的动态条件、循环等逻辑。Mapper.xml可以使得SQL语句的编写更加灵活,而且可以方便地对SQL语句进行管理和调试。 在实际使用中,通常建议使用Mapper.xml描述复杂的SQL语句逻辑,而使用Mapper.java来描述简单的SQL语句。同时,Mapper.java和Mapper.xml并不是互斥的,可以同时使用,也可以根据具体情况只使用其中一种。无论是使用Mapper.java还是Mapper.xml,都可以通过MyBatis框架来解析映射描述文件,并根据映射关系来执行SQL语句。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值