springboot集成通用mapper详细配置
通常,我们利用mybatis写持久层方法。要么按照传统定义mapper方法,定义xml文件的方式,全部手写。要么需要通过mybatis-generator逆向工程插件生成大量的xxxExample文件,使得系统看起来比较臃肿。而通用mapper的引入,我们不需再生成大量的Example文件,并且通用mapper已经封装好了所有的单表操作。通用mapper与springboot项目集成配置如下:
pom.xml配置
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper-spring-boot-starter</artifactId>
<version>RELEASE</version>
</dependency>
定义通用Mapper基类
package com.gogle.mgt.dataaccess.mybatis;
import tk.mybatis.mapper.common.Mapper;
import tk.mybatis.mapper.common.MySqlMapper;
/**
* @ClassName TkMapper
* @Description TODO
* @Date 2019/7/16 16:15
* @Created by sunyiwei
*/
public interface TkMapper<T> extends Mapper<T>,MySqlMapper<T> {
}
yml文件配置
mybatis:
mapper-locations: classpath:mapper/*.xml #定义xml文件位置,不是必须的,如果需要在xml写sql请配置此选项
type-aliases-package: com.gogle.mgt.domain # 注意:对应实体类的路径
mapper:
mappers: com.gogle.mgt.dataaccess.mybatis.TkMapper #通用基类配置
identity: MYSQL
注:通用基类请不要与我们下面要定义的mapper位于同一包下,否则运行会报错。
定义MapperScan
package com.gogle.mgt;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
import tk.mybatis.spring.annotation.MapperScan;
@EnableEurekaClient
@EnableFeignClients
@SpringBootApplication
@MapperScan(basePackages = { "com.gogle.mgt.dataaccess.mybatis.dao" })
public class VslmApplication {
public static void main(String[] args) {
SpringApplication.run(VslmApplication.class, args);
}
}
注:此处MapperScan为tk.mybatis.spring.annotation.MapperScan,非org.mybatis.spring.annotation.MapperScan;
定义实体类
package com.gogle.mgt.domain;
import javax.persistence.Column;
import javax.persistence.Id;
import javax.persistence.Table;
import java.util.Date;
/**
* @ClassName StreamLine
* @Description TODO
* @Date 2019/7/16 16:16
* @Created by sunyiwei
*/
@Table(name="stream_line")
public class StreamLine {
@Id
String streamLineId;
@Column(name = "name")
String name;
@Column(name = "area")
String area;
@Column(name = "spec_id")
String specId;
@Column(name = "vpl_id")
String vplId;
@Column(name = "status")
byte status;
@Column(name = "create_time")
Date createTime;
@Column(name = "modify_time")
Date modifyTime;
@Column(name = "modify_person")
String modifyPerson;
public StreamLine() {
}
}
注:如果bean实体中含有数据表中不存在的字段,使用@Transient注解
mapper定义
package com.gogle.mgt.dataaccess.mybatis.dao;
import com.gogle.mgt.dataaccess.mybatis.TkMapper;
import com.gogle.mgt.domain.StreamLine;
import org.apache.ibatis.annotations.Select;
import org.springframework.stereotype.Repository;
import java.util.List;
/**
* @ClassName StreamLineMapper
* @Description TODO
* @Date 2019/7/16 16:23
* @Created by sunyiwei
*/
@Repository
public interface StreamLineMapper extends TkMapper<StreamLine> {
/**
* 注解sql
* @return
*/
@Select("select * from stream_line")
List<StreamLine> getAll();
/**
* xml定义语句
*/
StreamLine getById(String streamLineId);
}
注:mapper中已经继承了TkMapper里面的所有单表操作的增删改查方法,上面的两个方法
getAll与getById是我们自定义的方法,一种通过注解定义,另外一种是我们常用的在xml文件里面写方法。
测试
package com.gogle.mgt;
import java.util.List;
/**
* @ClassName MapperTest
* @Description TODO
* @Date 2019/7/16 16:28
* @Created by sunyiwei
*/
@RunWith(SpringRunner.class)
@SpringBootTest
public class MapperTest {
@Autowired
private StreamLineMapper mapper;
/**
* 继承自通用mapper的单表操作方法测试
*/
@Test
public void test(){
StreamLine line = new StreamLine();
line.setStreamLineId("001");
line.setArea("萧山");
int insert = mapper.insert(line);
System.out.println(insert);
}
/**
* 我们注解自定义的方法测试
*/
@Test
public void test2(){
List<StreamLine> all = mapper.getAll();
System.out.println(all);
}
/**
* xml文件中定义接口测试
*/
@Test
public void test3(){
StreamLine one = mapper.getById("001");
System.out.println(one);
}
}
springboot集成通用mapper详细配置的更多相关文章
- springboot 集成eureka 超详细配置
撸了今年阿里.头条和美团的面试,我有一个重要发现.......>>> 原文链接: https://blog.csdn.net/nanbiebao6522/article/detail ...
- SpringBoot集成MyBatis的Bean配置方式
SpringBoot集成MyBatis的Bean配置方式 SpringBoot是一款轻量级开发的框架,简化了很多原先的xml文件配置方式,接下来就介绍一下如何不适用XML来配置Mybatis spri ...
- SpringBoot之集成通用Mapper
第一种: 1.引入POM坐标,需要同时引入通用mapper和jpa <dependency> <groupId>tk.mybatis</groupId> <a ...
- Springboot整合通用mapper
通用Mapper的分享使用 参考博客 Mybatis的通用mapper和Hibernate一样都实现了JPA接口,简化了数据库的操作 和Hibernate的对比 Hibernate和Mybatis都是 ...
- springboot搭建通用mapper
对于搭建一个小项目自己测试玩如果采用传统的SSM框架配置起来太过于繁琐,使用springboot简化配置再搭配通用mapper简直不要太方便,话不多说,直接上代码. 首先是pom文件,直接去sprin ...
- 集成通用Mapper
通用Mapper集成 1.引入jar包 <mapper.version>3.0.1</mapper.version><persistence-api.version> ...
- springboot学习笔记:9.springboot+mybatis+通用mapper+多数据源
本文承接上一篇文章:springboot学习笔记:8. springboot+druid+mysql+mybatis+通用mapper+pagehelper+mybatis-generator+fre ...
- springboot与通用mapper的整合
找到springboot工程下的pom.xml文件,导入如下的依赖jar包 <!--配置通用Mapper start--> <dependency> <groupId&g ...
- Springboot 整合通用mapper和pagehelper展示分页数据(附github源码)
简介 springboot 设计目的就是为了加速开发,减少xml的配置.如果你不想写配置文件只需要在配置文件添加相对应的配置就能快速的启动的程序. 通用mapp 通用mapper只支持对单表的操作,对 ...
随机推荐
- 一起了解 .Net Foundation 项目 No.15
.Net 基金会中包含有很多优秀的项目,今天就和笔者一起了解一下其中的一些优秀作品吧. 中文介绍 中文介绍内容翻译自英文介绍,主要采用意译.如与原文存在出入,请以原文为准. NUnit Test Fr ...
- mac 工具推荐
传送门: https://github.com/jaywcjlove/awesome-mac/blob/master/README-zh.md
- H5系列一、静态页面总结
1.img父标签设置高度,如果容器没有设置高度的话,图片会默认把容器底部撑大几像素 -- 大概3px,给容器设置高度. 2.input标记换行后默认有一个间隙,设置float属性.input标记默认还 ...
- TEA5676 + AT24C08 FM收音机 搜台 存台 mmap 实现读写
硬件说明TEA5767 + AT24c08 要使用耳机收听,不加功放芯片,声音非常小. 这2个芯片都支持 3.3 或 5.0 电源支持连线比较简单,sda scl 接到 2440 对应的 排针上,找出 ...
- adb模拟按键与输入
在 adb shell 里有个很实用的命令叫 input,通过它可以做一些有趣的事情. input 命令的完整 help 信息如下: Usage: input [<source>] < ...
- Block详解一(底层分析)
本篇博客不再讲述Block的基本定义使用,最近而是看了很多的block博客讲述的太乱太杂,所以抽出时间整理下block的相关底层知识,在讲述之前,提出几个问题,如果都可以回答出来以及知道原理,大神绕过 ...
- 01.UNIX基础知识
1.UNIX体系结构 什么叫做内核? 内核是一种软件,它控制计算机硬件资源,并提供程序的运行环境. 什么叫操作系统? 在广义上,操作系统包括了内核和一些其他软件,这些软件使得计算机能够发挥作用,如可以 ...
- 深入解析Underscore.js源码架构
Underscore.js是很有名的一个工具库,我也经常用他来处理对象,数组等,本文会深入解析Underscore源码架构,跟大家一起学习下他源码的亮点,然后模仿他写一个简单的架子来加深理解.他的源码 ...
- 【Weiss】【第04章】AVL树例程
普通的二叉搜索树可能会由于数据不平均.删除产生高度差等原因,使树倾向于不平衡生长,导致操作慢于O(NlogN). 为应对此现象,将搜索.删除.插入的最坏时间也控制在O(NlogN)上,产生了平衡二叉树 ...
- java猜数游戏(新手记录每天的作业)
//导入包 import java.util.Scanner;import java.util.Random; //定义一个类 public class Zcs{ //公共静态的主方法 public ...