• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

你应该知道的这些Mybatis-Plus使用技巧(小结)

mybatis 搞代码 4年前 (2022-01-09) 19次浏览 已收录 0个评论

最近在用 Mybatis-Plus,嗯,真香!!!今天就来说说 Mybatis-Plus 的那些使用技巧

1、条件查询(QueryWrapper)

如果说,我们需要查询的 SQL 语句如下:

SELECT * FROM user_info WHERE 1=1 AND age = 20

那么对应的代码可以为:

QueryWrapper<UserInfo> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("age", 20);
List<UserInfo> list = userInfoMapper.selectList(queryWrapper );

以上就是查询用户表,用户年龄大于20的用户信息

2、条件查询(QueryWrapper lambda)

QueryWrapper<UserInfo> queryWrapper = new QueryWrapper<>();
queryWrapper.lambda().eq(UserInfo::getAge, 20);
List<UserInfo> list = userInfoMapper.selectList(queryWrapper );

以上就是 QueryWrapper 的 lambda 表达式写法,这样能够避免写字段名写错,或者未转换驼峰写法导致 SQL 错误

3、条件查询(LambdaQueryWrapper)

LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getAge, 20);
List<UserInfo> list = userInfoMapper.selectList(queryWrapper );

LambdaQueryWrapper 与 QueryWrapper 的 lambda 写法基本一致

4、分页查询

// 条件查询
LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getAge, 20);
// 分页对象
Page<UserInfo> queryPage = new Page<>(page, limit);
// 分页查询
IPage<UserInfo> iPage = userInfoMapper.selectPage(queryPage , queryWrapper);
// 数据总数
Long total = iPage.getTotal();
// 用户数据
List<UserInfo> list = iPage.getRecords();

以上就是分页查询,如果无需条件查询,queryWrapper 可为 null

5、分页查询(联表)

当我们需要关联表格分页查询时,第3步已经满足不了我们的需求了,那么我们需要进行联表分页查询

假设我们需要的 SQL 语句如下:

SELECT
 a.*,
 b.`name` AS sex_text 
FROM
 user_info a
 LEFT JOIN user_sex b ON ( a.sex = b.id ) 
WHERE
 1 = 1 
 AND a.age > 20

那么我们需要进行如下操作:

1、新建 UserInfoVO.java

import com.zyxx.entity.UserInfo;
import lombok.Data;

@Data
public class UserInfoVO extends UserInfo {

  // 性别
  private String sexText;
}

2、UserInfoMapper.java 中

IPage<UserInfoVO> list(Page<UserInfoVO> page, @Param(Constants.WRAPPER) Wrapper<UserInfoVO> queryWrapper);

3、UserInfoMapper.xml 中

<select id="list" resultType="com.zyxx.vo.UserInfoVO">
  SELECT
 a.<strong style="color:transparent">来2源gaodaima#com搞(代@码&网</strong>*,
 b.`name` AS sex_text 
 FROM
 user_info a
 LEFT JOIN user_sex b ON ( a.sex = b.id ) 
  ${ew.customSqlSegment}
</select>

4、UserInfoServiceImpl.java 中

// 条件查询
LambdaQueryWrapper<UserInfoVO> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getAge, 20);
// 分页对象
Page<UserInfoVO> queryPage = new Page<>(page, limit);
// 分页查询
IPage<UserInfoVO> iPage = userInfoMapper.list(queryPage , queryWrapper);
// 数据总数
Long total = iPage.getTotal();
// 用户数据
List<UserInfoVO> list = iPage.getRecords();

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:你应该知道的这些Mybatis-Plus使用技巧(小结)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址