首先创建一个数据库表,如下图所示:
然后创建一个Spring Boot项目,pom.xml和配置如下:
4.0.0 org.kaven mybatis-plus1.0-SNAPSHOT org.springframework.boot spring-boot-starter-parent2.3.4.RELEASE 1.8 org.springframework.boot spring-boot-starterorg.springframework.boot spring-boot-starter-testorg.springframework.boot spring-boot-starter-webfluxcom.baomidou mybatis-plus-boot-starter3.4.0 mysql mysql-connector-java5.1.49 org.projectlombok lombokorg.springframework.boot spring-boot-maven-plugin
spring: application: name: mybatis-plus datasource: driver-class-name: com.mysql.jdbc.Driver username: root password: ITkaven@123 url: jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf-8&useSSL=false server: port: 8085 logging: level: root: warn com.kaven.mybatisplus.dao: trace pattern: console: '%p%m%n' mybatis-plus: mapper-locations: classpath:mappers @TableField(exist = false) private String phone; }
Mapper接口UserMapper:
package com.kaven.mybatisplus.dao; import com.baomidou.mybatisplus.core.mapper.baseMapper; import com.kaven.mybatisplus.entity.User; import org.springframework.stereotype.Component; @Component public interface UserMapper extends baseMapper{}
启动类:
package com.kaven.mybatisplus;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@MapperScan(basePackages = "com.kaven.mybatisplus.dao")
public class AppRun {
public static void main(String[] args) {
SpringApplication.run(AppRun.class , args);
}
}
@MapperScan(basePackages = "com.kaven.mybatisplus.dao")这个一定要加上。
我们先在数据库中添加几行数据,方便演示。
一:查询username包含字符k,并且age要小于35,只需要输出username、age即可。
package com.kaven.mybatisplus.dao;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.kaven.mybatisplus.entity.User;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
import java.util.Arrays;
import java.util.List;
@RunWith(SpringRunner.class)
@SpringBootTest
public class UserMapperTest {
@Autowired
private UserMapper userMapper;
@Test
public void selectList(){
QueryWrapper userQueryWrapper = new QueryWrapper<>();
// QueryWrapper userQueryWrapper = Wrappers.query(); 和上面一样的效果
userQueryWrapper.select("username", "age").like("username" , "k").lt("age" , 35);
// userQueryWrapper.like("username" , "k").lt("age" , 35).select("username", "age");
// 把select()放在最后面也可以,但我一般喜欢放在最前面,和sql语法保持一致
List userList = userMapper.selectList(userQueryWrapper);
userList.forEach(System.out::println);
}
}
结果如下:
很显然,结果是正确的。
当数据库表有很多列,并且需要输出大部分列时,用这种方法来指定字段查询就很繁琐,这也是不可避免的。
二:查询username包含字符k,并且age要大于等于25并且小于等于35、password不能为null,不需要输出password。
package com.kaven.mybatisplus.dao;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.kaven.mybatisplus.entity.User;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
import java.util.Arrays;
import java.util.List;
@RunWith(SpringRunner.class)
@SpringBootTest
public class UserMapperTest {
@Autowired
private UserMapper userMapper;
@Test
public void selectList2(){
QueryWrapper userQueryWrapper = new QueryWrapper<>();
// QueryWrapper userQueryWrapper = Wrappers.query(); 和上面一样的效果
userQueryWrapper.select(User.class , e->!e.getColumn().equals("password")).like("username" , "k")
.between("age" , 25 , 35)
.isNotNull("password");
List userList = userMapper.selectList(userQueryWrapper);
userList.forEach(System.out::println);
}
}
结果如下:
结果也是正确的。
这两种方法各有优缺点,可以互补使用。
到此这篇关于MyBatis-Plus 查询指定字段的实现的文章就介绍到这了,更多相关MyBatis-Plus 查询指定字段内容请搜索考高分网以前的文章或继续浏览下面的相关文章希望大家以后多多支持考高分网!



