mybatiplus的apply_Mybatis-Plus条件构造器查询

本文通过9个实例介绍了如何使用Mybatis-Plus的条件构造器QueryWrapper进行条件查询,包括like、between、in等操作,并展示了对应的SQL日志输出。
摘要由CSDN通过智能技术生成

Mybatis-Plus使用条件构造器(QueryWrapper)进行条件查询的9个小例子

首先创建user表

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, '刘红雨', 31, 'lhm@baomidou.com', 1088248166370832385, '2019-01-14 09:48:16' );

名字中包含“雨”并且年龄小于40

name like '%雨%' and age<40

@Test

public void selectByWrapper1() {

QueryWrapper queryWrapper = new QueryWrapper<>();

// lt为小于的意思

queryWrapper.like("name", "雨").lt("age", 40);

List users = userMapper.selectList(queryWrapper);

users.forEach(System.out::println);

}

日志输出sql:

DEBUG==> Preparing: SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age < ?

DEBUG==> Parameters: %雨%(String), 40(Integer)

TRACE<== Columns: id, name, age, email, manager_id, create_time

TRACE<== Row: 1094590409767661570, 张雨琪, 31, zjq@baomidou.com, 1088248166370832385, 2019-01-14 09:15:15

TRACE<== Row: 109459204108772966

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值