SpringBoot集成Mybatis-Plus使用

最近web端比较热门的框架就是SpringBoot和Mybatis-Plus,这里简单总结集成用法。

Mybatis-Plus是一个很强大而且方便的ORM框架,而且对SpringBoot也进行了适配,用起来简易,官方网站也有中文文档

引入Jar

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.0.2</version>
</dependency>

Mybatis-Plus对SpringBoot进行了适配,所以可如此引入。下面的Jar可用于SpringMVC或者单独使用

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus</artifactId>
    <version>3.0.2</version>
</dependency>

全局配置

spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&useSSL=true
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

mybatis-plus.type-aliases-package=com.plf.springbootmybatisplus.entity
#AUTO 数据库自增ID;ID_WORKER 全局唯一ID,内容为空自动填充(默认配置);
#INPUT 用户输入ID;UUID 全局唯一ID,内容为空自动填充
mybatis-plus.global-config.db-config.id-type=AUTO 
mybatis-plus.global-config.db-config.table-underline=true

实体类

import java.util.Date;

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;

@TableName
public class Log {
	@TableId
	private Integer id;
	
	@TableField
	private String content;
	
	@TableField
	private Date createtime;

	public Integer getId() {
		return id;
	}

	public void setId(Integer id) {
		this.id = id;
	}

	public String getContent() {
		return content;
	}

	public void setContent(String content) {
		this.content = content;
	}

	public Date getCreatetime() {
		return createtime;
	}

	public void setCreatetime(Date createtime) {
		this.createtime = createtime;
	}
}

Mybatis-Plus配置类

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;

@Configuration
@MapperScan("com.plf.springbootmybatisplus.mapper*")
public class MybatisPlusConfig {
   @Bean
   public PaginationInterceptor paginationInterceptor() {
      return new PaginationInterceptor();
   }
}

Mapper类

import org.springframework.stereotype.Repository;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.plf.springbootmybatisplus.entity.Log;

@Repository
public interface LogMapper extends BaseMapper<Log>{

}

上述接口继承BaseMapper<Log>,即可使用通用方法

接口方法

import com.baomidou.mybatisplus.extension.service.IService;
import com.plf.springbootmybatisplus.entity.Log;

public interface LogService extends IService<Log>{
	
	public void insertLog(Log log);
}

接口实现类

@Service
public class LogServiceImpl extends ServiceImpl<BaseMapper<Log>,Log> 
		implements LogService {

	@Override
	public void insertLog(Log log) {
		baseMapper.insert(log);
	}

}

控制器类

import java.util.Date;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.plf.springbootmybatisplus.entity.Log;
import com.plf.springbootmybatisplus.service.impl.LogServiceImpl;

@RestController
@RequestMapping("/log")
public class LogController {

	@Autowired
	private LogServiceImpl logServiceImpl; 
	
	//日志插入
	@RequestMapping("/add")
	public String addLog(Log log){
		log.setCreatetime(new Date());
		logServiceImpl.insertLog(log);
		return "success";
	} 
}

调用接口

http://localhost:8080/log/add?content=test

逻辑删除

配置逻辑值
# 已删除表示1
mybatis-plus.global-config.db-config.logic-delete-value=1
# 未删除表示0
mybatis-plus.global-config.db-config.logic-not-delete-value=0
注入LogicSqlInjector
@Bean
public ISqlInjector sqlInjector(){
    return new LogicSqlInjector();
}
实体类标注逻辑删除字段
@TableField
@TableLogic
private Integer delstatus;
测试
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;

@RunWith(SpringRunner.class)
@SpringBootTest
public class LogServiceTest {

	@Autowired
	private LogService logService;
	
	@Test
	public void delLog(){
		logService.deleteLog(5);
	}
	
}
结果
后台执行如下语句
UPDATE log SET delstatus=1 WHERE id=? AND delstatus=0 

分页查询

注入分页插件
@Bean
public PaginationInterceptor paginationInterceptor() {
  return new PaginationInterceptor();
}
编写接口方法
public Page<Log> getPageLog(Page<Log> page, String strattime);
实现接口方法
@Override
public Page<Log> getPageLog(Page<Log> page, String starttime) {
	return (Page<Log>) baseMapper.selectPage(page,
	 new QueryWrapper<Log>().select("content,createtime,user_id").gt("createtime",starttime));
}
测试
@Test
public void ListPage(){
	Page<Log> page=logService.getPageLog(new Page<Log>(1,2), "2018-10-09");
	System.out.println("total:"+page.getTotal());
	List<Log> list = page.getRecords();
	for (Log log : list) {
		System.out.println(log);
	}
}
结果
后台SQL语句

Preparing: SELECT COUNT(1) FROM log WHERE delstatus = 0 AND createtime > ? 
Parameters: 2018-10-09(String)
Preparing: SELECT content,createtime,user_id FROM log WHERE delstatus=0 AND createtime > ? LIMIT 0,2 
Parameters: 2018-10-09(String)
Total: 2

结果

total:3
Log [id=null, userId=1, content=test, 
	createtime=Wed Oct 10 21:03:17 CST 2018, delstatus=null]
Log [id=null, userId=1, content=test2, 
	createtime=Thu Oct 11 20:51:47 CST 2018, delstatus=null]

自定义联表分页查询

新建DTO类用于接受联表字段
import java.util.Date;

public class LogDto{
	private String content;
	
	private Date createtime;
	
	private String username;

	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public String getContent() {
		return content;
	}

	public void setContent(String content) {
		this.content = content;
	}

	public Date getCreatetime() {
		return createtime;
	}

	public void setCreatetime(Date createtime) {
		this.createtime = createtime;
	}

	@Override
	public String toString() {
		return "LogDto [content=" + content + ", createtime=" + createtime + ", username=" + username + "]";
	}
}

在LogMapper中编写SQL语句
@Select("select l.content,u.username,l.createtime from log l"
		+ " left join user u on l.user_id=u.id"
		+ " where u.username=#{username}")
public List<LogDto> getLogAndName(Page<LogDto> page,@Param("username")String username);
编写接口方法
public Page<LogDto> getLogAndName(Page<LogDto> page, String username);
实现接口方法
@Override
public Page<LogDto> getLogAndName(Page<LogDto> page, String username) {
	List<LogDto> records = baseMapper.getLogAndName(page,username);
	page.setRecords(records);
	return page;
}
测试
@Test
public void ListPageAndName(){
	Page<LogDto> page=logService.getLogAndName(new Page<LogDto>(1,2), "小白");
	List<LogDto> list = page.getRecords();
	for (LogDto logDto : list) {
		System.out.println(logDto);
	}
}
结果
后台SQL语句

Preparing: SELECT COUNT(1) FROM log l LEFT JOIN user u ON l.user_id = u.id WHERE u.username = ? 
Parameters: 小白(String)
Preparing: select l.content,u.username,l.createtime from log l left join user u on l.user_id=u.id where u.username=? LIMIT 0,2 
小白(String)
Total: 2


结果

LogDto [content=测试1, createtime=Sun Oct 07 21:01:37 CST 2018, username=小红]
LogDto [content=test, createtime=Wed Oct 10 21:03:17 CST 2018, username=小红]

条件构造器

从官网搬运过来的,方便自己查看。

查询方式说明
setSqlSelect设置 SELECT 查询字段
whereWHERE 语句,拼接 + WHERE 条件
andAND 语句,拼接 + AND 字段=值
andNewAND 语句,拼接 + AND (字段=值)
orOR 语句,拼接 + OR 字段=值
orNewOR 语句,拼接 + OR (字段=值)
eq等于=
allEq基于 map 内容等于=
ne不等于<>
gt大于>
ge大于等于>=
lt小于<
le小于等于<=
like模糊查询 LIKE
notLike模糊查询 NOT LIKE
inIN 查询
notInNOT IN 查询
isNullNULL 值查询
isNotNullIS NOT NULL
groupBy分组 GROUP BY
havingHAVING 关键词
orderBy排序 ORDER BY
orderAscASC 排序 ORDER BY
orderDescDESC 排序 ORDER BY
existsEXISTS 条件语句
notExistsNOT EXISTS 条件语句
betweenBETWEEN 条件语句
notBetweenNOT BETWEEN 条件语句
addFilter自由拼接 SQL
last拼接在最后,例如:last(“LIMIT 1”)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值