MybatisPlus之QueryWrapper与LambdaQueryWrapper的用法及区别

本文详细介绍了MyBatis中QueryWrapper和LambdaQueryWrapper的使用方法,包括条件构造、排序和分页等操作。通过示例代码展示了两者在查询上的应用,并分析了它们的区别。LambdaQueryWrapper以其编译时检查的优势,提供了更安全的编码体验。
摘要由CSDN通过智能技术生成
/**
 * 1. QueryWrapper 用法示例
 */
List<UserDo> userList = userMapper.selectList(new QueryWrapper<UserDo>()
        .like("email", "24252")
        .between("age", 20, 22)
        .or()
        .eq("name", "zcx")
);
System.out.println("userList:" + userList.toString());

//2、排序用法
List<UserDo> users = userMapper.selectList(new QueryWrapper<UserDo>()
        .eq("nick_name", "xx")
        .orderByAsc("age")  //升序
        //                .orderByDesc("age") //降序
        .last("limit 0,3") //last用法:在sql末尾添加sql语句,有sql注入风险
);
System.out.println("users:"+users.toString());
/**
 * 2. LambdaQueryWrapper 用法示例
 */
LambdaQueryWrapper<UserDo> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserDo::getAccount, account);
queryWrapper.eq(UserDo::getIsDelete, 0);
queryWrapper.like(UserDo::getName,"lk");
queryWrapper.between(UserDo::getAge,18,20);
// queryWrapper.orderByAsc(UserDo::getDeptNo);
UserDo user = userMapper.selectOne(queryWrapper);
Integer count = userMapper.selectCount(queryWrapper);
UserDo user1 = userMapper.selectOne(new LambdaQueryWrapper<UserDo>()
.eq(UserDo::getAccount, username));
/**
 * 3. 区别
 * 
 * QueryWrapper 的列名匹配使用的是 “数据库中的字段名(一般是下划线规则)”
 * LambdaQueryWrapper 的列名匹配使用的是“Lambda的语法,偏向于对象”
 * 不同写“列名”,而是使用纯java的方式,避免了拼写错误(LambdaQueryWrapper 的写法如果有错,
 * 则在编译期就会报错,而QueryWrapper需要运行的时候调用该方法才会报错)
 * 所以LambdaQueryWrapper 更优于 QueryWrapper
 */

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值