前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >每天玩转3分钟 MyBatis-Plus - 6. select 用法

每天玩转3分钟 MyBatis-Plus - 6. select 用法

作者头像
悟空聊架构
发布2020-02-17 15:13:06
2.1K0
发布2020-02-17 15:13:06
举报

代码下载:https://github.com/Jackson0714/study-mybatis-plus.git

mybatis-plus的查询功能非常强大, 上一篇,我们通过例题的方式讲解了mybatis-plus的高级查询功能:条件查询.

这一篇我们继续以例题的方式讲解mybatis-plus的 select 查询功能。

准备数据

代码语言:javascript
复制
#创建用户表
CREATE TABLE user (
    id BIGINT(20) PRIMARY KEY NOT NULL COMMENT '主键',
    name VARCHAR(30) DEFAULT NULL COMMENT '姓名',
    age INT(11) DEFAULT NULL COMMENT '年龄',
    email VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
    manager_id BIGINT(20) DEFAULT NULL COMMENT '直属上级id',
    create_time DATETIME DEFAULT NULL COMMENT '创建时间',
    CONSTRAINT manager_fk FOREIGN KEY (manager_id)
        REFERENCES user (id)
)  ENGINE=INNODB CHARSET=UTF8;

#初始化数据:
INSERT INTO user (id, name, age, email, manager_id
    , create_time)
VALUES (1087982257332887553, '大boss', 40, 'boss@baomidou.com', NULL, '2019-01-11 14:20:20'),
    (1088248166370832385, '王天风', 25, 'wtf@baomidou.com', 1087982257332887553, '2019-02-05 11:12:22'),
    (1088250446457389058, '李艺伟', 28, 'lyw@baomidou.com', 1088248166370832385, '2019-02-14 08:31:16'),
    (1094590409767661570, '张雨琪', 31, 'zjq@baomidou.com', 1088248166370832385, '2019-01-14 09:15:15'),
    (1094592041087729666, '刘红雨', 32, 'lhm@baomidou.com', 1088248166370832385, '2019-01-14 09:48:16');

User 表结构如下:

id

name

age

email

manager_id

create_time

1

Jone

18

test1@baomidou.com

null

2020-01-01 14:20:20

2020-01-01 14:20:20

2020-01-01 14:20:20

2

Jack

20

test2@baomidou.com

1

2020-01-20 14:20:20

2020-01-20 14:20:20

2020-01-20 14:20:20

3

Tom

28

test3@baomidou.com

2

2020-01-15 14:20:20

2020-01-15 14:20:20

2020-01-15 14:20:20

4

Sandy

21

test4@baomidou.com

2

2020-01-12 14:20:20

2020-01-12 14:20:20

2020-01-12 14:20:20

5

Billie

24

test5@baomidou.com

2

2020-01-22 14:20:20

2020-01-22 14:20:20

2020-01-22 14:20:20

一、案例汇总(第四波)

1.1 查询年龄为20、21、25、26的用户,且只返回id和name字段

难度系数 ★

1.2 查询年龄为20、21、25、26的用户,且只返回id、name、manager_id字段

难度系数 ★★

二、案例讲解

1.1 查询年龄为20、21、25、26的用户,且只返回id和name字段

难度系数 ★

考察 select 用法

代码语言:javascript
复制
 1 /*
 2  * 描述:例1.9 查询年龄为20、21、25、26的用户,且只返回id和name字段
 3  * SQL语句:SELECT id,name FROM user WHERE age IN (20,21,25,26)
 4  * 作者:博客园-悟空聊架构
 5  * 时间:2019-02-01
 6  * Github:https://github.com/Jackson0714/study-mybatis-plus.git
 7  * 博客园:https://www.cnblogs.com/jackson0714
 8  * */
 9 @Test
10 public void testSelectByQueryWrapper9() {
11     System.out.println(("----- 查询年龄为20、21、25、26的用户,且只返回id和name字段 ------"));
12     QueryWrapper<User> queryWrapper = new QueryWrapper<>();
13     queryWrapper.in("age", Arrays.asList(20,21,25,26)).select("id","name"); // 针对字段少的情况
14     List<User> userList = userMapper.selectList(queryWrapper);
15     userList.forEach(System.out::println);
16 }

查询日志:

查询结果:

1.2 查询年龄为20、21、25、26的用户,且只返回id、name、manager_id字段

难度系数 ★★

考察 select 用法

代码语言:javascript
复制
 1 /*
 2  * 描述:例1.10 查询年龄为20、21、25、26的用户,且只返回id、name、manager_id 字段
 3  * SQL语句:SELECT id,name,manager_id FROM user WHERE age IN (20,21,25,26)
 4  * 作者:博客园-悟空聊架构
 5  * 时间:2019-02-01
 6  * Github:https://github.com/Jackson0714/study-mybatis-plus.git
 7  * 博客园:https://www.cnblogs.com/jackson0714
 8  * */
 9 @Test
10 public void testSelectByQueryWrapper10() {
11     System.out.println(("----- 查询年龄为20、21、25、26的用户,且只返回id、name、manager_id 字段 ------"));
12     QueryWrapper<User> queryWrapper = new QueryWrapper<>();
13     queryWrapper.in("age", Arrays.asList(20,21,25,26)) // 针对字段多的情况,用排除字段的方式
14             .select(User.class, info->!info.getColumn()
15                     .equals(("email")) && !info.getColumn().equals("create_time"));
16 
17     List<User> userList = userMapper.selectList(queryWrapper);
18     userList.forEach(System.out::println);
19 }

 查询日志:

 查询结果:

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-02-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、案例汇总(第四波)
    • 1.1 查询年龄为20、21、25、26的用户,且只返回id和name字段
      • 1.2 查询年龄为20、21、25、26的用户,且只返回id、name、manager_id字段
      • 二、案例讲解
        • 1.1 查询年龄为20、21、25、26的用户,且只返回id和name字段
          • 1.2 查询年龄为20、21、25、26的用户,且只返回id、name、manager_id字段
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档