<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0modelVersion>
<groupId>org.examplegroupId>
<artifactId>boot-plusartifactId>
<version>1.0-SNAPSHOTversion>
<parent>
<artifactId>spring-boot-starter-parentartifactId>
<groupId>org.springframework.bootgroupId>
<version>2.7.2version>
parent>
<dependencies>
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-webartifactId>
dependency>
<dependency>
<groupId>mysqlgroupId>
<artifactId>mysql-connector-javaartifactId>
dependency>
<dependency>
<groupId>org.projectlombokgroupId>
<artifactId>lombokartifactId>
dependency>
<dependency>
<groupId>com.baomidougroupId>
<artifactId>mybatis-plus-boot-starterartifactId>
<version>3.5.1version>
dependency>
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-testartifactId>
dependency>
<dependency>
<groupId>com.baomidougroupId>
<artifactId>mybatis-plus-generatorartifactId>
<version>3.5.3version>
dependency>
<dependency>
<groupId>org.apache.velocitygroupId>
<artifactId>velocity-engine-coreartifactId>
<version>2.3version>
dependency>
dependencies>
project>
package com.zlz;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class PlusStart {
public static void main(String[] args) {
SpringApplication.run(PlusStart.class);
}
}
package com.zlz;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.config.OutputFile;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import java.util.Collections;
public class MyGenerator {
public static void main(String[] args) {
FastAutoGenerator.create("jdbc:mysql://127.0.0.1:3305/db0618", "root", "root")
.globalConfig(builder -> {
builder.author("zlz") // 设置作者
.dateType(DateType.ONLY_DATE) // 时间策略,日期以什么样子的类型去生成
.outputDir("F:\\boot\\boot-plus\\src\\main\\java"); // 指定输出目录
})
.packageConfig(builder -> {
builder.parent("com.zlz") // 设置父包名
.pathInfo(Collections.singletonMap(OutputFile.xml, "F:\\boot\\boot-plus\\src\\main\\resources\\mapper")); // 设置mapperXml生成路径,
// 注意:这个mapper文件夹是可以不存在的,运行该main方法会自动创建的
})
.strategyConfig(builder -> {
//开启lombok
builder.entityBuilder().enableLombok();
//覆盖现有文件
builder.entityBuilder().fileOverride();
builder.addInclude("songs"); // 设置需要生成的表名,想一次性生成多张表,就用逗号隔开,如:addInclude("songs","music")
})
.execute();
}
}
package com.zlz.entity;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import java.io.Serializable;
import java.util.Date;
import lombok.*;
/**
*
*
*
*
* @author zlz
* @since 2023-01-02
*/
//①改动地方1
@AllArgsConstructor
@NoArgsConstructor
@Data
public class Songs implements Serializable {
private static final long serialVersionUID = 1L;
@TableId(value = "id", type = IdType.AUTO)
private Integer id;
private String singerName;
private String album;
private String albumImg;
private String name;
//②改动地方2,调成日期形式,就不用转型了
private String releaseDate;
}
spring:
datasource
url: jdbc:mysql://127.0.0.1:3305/db0618
driver-class-name: com.mysql.cj.jdbc.Driver
username: root
password: root
mybatis-plus:
type-aliases-package: com.zlz.entity #实体别名扫描
#配置日志 查看具体的sql执行语句
logging:
level:
com.zlz.mapper: debug
package com.zlz.config;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Configuration;
@Configuration
@MapperScan("com.zlz.mapper")//mapper接口扫描,@MapperScan也可以放在启动类PlusStart上面(启动类也算配置类)
public class PlusConfig {
}
import com.zlz.PlusStart;
import com.zlz.service.ISongsService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest(classes = PlusStart.class,
webEnvironment = SpringBootTest.WebEnvironment.NONE)
public class MyTest {
@Autowired
ISongsService songsService;
}
@Test
public void findOne(){
Songs byId = songsService.getById(666);
System.out.println(byId);
}
@Test
public void findAll(){
List<Songs> list = songsService.list();
for (Songs songs : list) {
System.out.println(songs);
}
}
//带上条件的查询(使用场景:商城商品的关键字搜索)
@Test
public void findByCondition(){
//查询条件构造器
String search="张学友";
QueryWrapper<Songs> qw = new QueryWrapper<>();
//第一个参数是条件,如果条件为真就带上第三个参数,为假就不带上,第二个参数是表的字段名
qw.eq(search!=null, "singer_name",search);
List<Songs> list = songsService.list(qw);
for (Songs songs : list) {
System.out.println(songs);
}
}
@Test
public void findByCondition(){
//范围查找between
QueryWrapper<Songs> qw = new QueryWrapper<>();
qw.between("release_date", "2000-1-1","2020-1-1");
List<Songs> list = songsService.list(qsw);
for (Songs songs : list) {
System.out.println(songs);
}
}
@Test
public void findByCondition(){
//查询条件构造器
QueryWrapper<Songs> qw = new QueryWrapper<>();
//查询歌曲表中歌手名字以张开头的所有歌手信息
qw.likeRight("singer_name", "张");
List<Songs> list = songsService.list(qw);
for (Songs songs : list) {
System.out.println(songs);
}
}
public void findByCondition(){
//查询条件构造器
QueryWrapper<Songs> qw = new QueryWrapper<>();
//查询某些列是用逗号去进行分开,然后查到了的数据才有值,没有查到的数据就都是null值
qw.select("id,name");
List<Songs> list = songsService.list(qw);
for (Songs songs : list) {
System.out.println(songs);
}
}
@Test
public void findByGroup(){
//统计歌曲表中每个歌手唱了多少首歌
//① 创建QueryWrapper对象
QueryWrapper<Songs> qw = new QueryWrapper<>();
//② 指定分组字段
qw.groupBy("singer_name");
//下面的select方法相当于的sql语句是 select singer_name,count(*) num from songs group by singer_name;
//③指定要查询出来的列
qw.select("singer_name,count(*) num");
//因为是多条数据,一条数据就相当于一个map,所以需要用List
//④使用listMaps方法去进行查询
List<Map<String, Object>> maps = songsService.listMaps(qw);
for (Map<String, Object> map : maps) {
System.out.println(map);
}
}
g 排序查询
g.1 示例代码
//排序的使用
@Test
public void findByOrder(){
//把歌曲表按照日期降序排列
QueryWrapper<Songs> qw = new QueryWrapper<>();
//如果想要指定多个字段排序,那么可以使用逗号隔开,如orderByDesc("字段1,字段2...")
qw.orderByDesc("release_date");
songsService.list(qw).forEach(System.out::println);
}
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
//设置分页插件,别的拦截器也是addInnerInterceptor加入进去
PaginationInnerInterceptor pi = new PaginationInnerInterceptor();
pi.setDbType(DbType.MYSQL);//设置数据库类型为MySQL
pi.setOverflow(true);//溢出分页处理,默认是false不处理,需要设置成true,保证分页合理化
interceptor.addInnerInterceptor(pi);
return interceptor;
}
package com.zlz.config;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
@MapperScan("com.zlz.mapper")//mapper接口扫描,@MapperScan也可以放在启动类PlusStart上面(启动类也算配置类)
public class PlusConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
//设置分页插件,别的拦截器也是addInnerInterceptor加入进去
PaginationInnerInterceptor pi = new PaginationInnerInterceptor();
pi.setDbType(DbType.MYSQL);//设置数据库类型为MySQL
pi.setOverflow(true);//溢出分页处理,默认是false不处理,需要设置成true,保证分页合理化
interceptor.addInnerInterceptor(pi);
return interceptor;
}
}
@Test
public void findByPage(){
//创建分页对象
IPage<Songs> page = new Page<>(1, 5);
//条件构造器
QueryWrapper<Songs> qw = new QueryWrapper<>();
qw.like("name", "天");
//如果有条件的话,就把条件构造器对象丢到它的第二个形参就是的
songsService.page(page,qw);
//输出
List<Songs> records = page.getRecords();
for (Songs record : records) {
System.out.println(record);
}
//页码相关
System.out.println("当前页码:"+page.getCurrent());
System.out.println("总条数:"+page.getTotal());
System.out.println("总页数:"+page.getPages());
}
List<Songs> find(IPage<Songs> page, String album);
<select id="find" resultType="songs">
SELECT * FROM songs WHERE album like #{album}
select>
d.3 测试代码
//自定义分页,要注入自己的mapper
@Autowired
SongsMapper songsMapper;
@Test
public void findByCustomPage(){
//创建分页对象
IPage<Songs> page = new Page<>(1, 5);
String search="年";
List<Songs> songs = songsMapper.find(page, "%" + search + "%");
System.out.println(songs);
//页码相关
System.out.println("当前页码:"+page.getCurrent());
System.out.println("总条数:"+page.getTotal());
System.out.println("总页数:"+page.getPages());
}