MybatisPlus_${ew.sqlSelect},${ew.sqlSet},${ew.sqlSegment},${ew.customSqlSegment}的使用

说明:

${ew.sqlSelect}

        拼接select SQL主体

${ew.sqlSet}

        拼接update SQL主体

${ew.sqlSegment}

        拼接where后的语句

${ew.customSqlSegment}

        拼接where后的语句(包括where。需注意在动态SQL中勿处于<where></where>标签内)

演示:

Mapper接口

@Mapper
@Repository
public interface UserMapper extends BaseMapper<User> {
    List<User> queryAll(@Param("tableName") String tableName,@Param(Constants.WRAPPER) Wrapper wrapper);
    
    boolean updateById(@Param("tableName") String tableName,@Param("id") int id,@Param(Constants.WRAPPER) Wrapper wrapper);//若变量名为ew则无需注解
}

XML

    <select id="queryAll" resultType="cn.alan.mybatis.POJO.User">
        select ${ew.sqlSelect} from ${tableName} ${ew.customSqlSegment};
    </select>

    <update id="updateById">
        update ${tableName} set ${ew.sqlSet} ${ew.customSqlSegment};
    </update>

Controller(或Test)

    @Autowired
    UserServiceImpl userService;

    @RequestMapping("/query")
    public List<User> queryAll(){
        QueryWrapper<User> wrapper = new QueryWrapper<>();

        wrapper.select("*").eq("age","10");

        return  userService.queryAll("user",wrapper);

        //return userService.queryAll("user", Wrappers.query().select("*").eq("age","10"));
    }

    @RequestMapping("/update")
    public boolean upDateById(){
        UpdateWrapper<User> wrapper = new UpdateWrapper<>();

        wrapper.set("name","5").eq("id","5");

        return userService.updateById("user",5,wrapper);

        //return userService.updateById("user",5,Wrappers.update().set("name","5").eq("id",5));
    }
}

注:关于wrapper的写法都是正确的,但后者需要注意使用的是静态类Wrappers

等效select SQL:select * from user where age = 10;

等效update SQL:update user set name = 5 where id = 5;

  • 3
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值