配置

POM文件

<parent>
<groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.5.6.RELEASE</version><relativePath />
</parent><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding><java.version>1.8</java.version>
</properties><dependencies><dependency><groupId>tk.mybatis</groupId><artifactId>mapper-spring-boot-starter</artifactId><version>RELEASE</version></dependency><dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId><version>RELEASE</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>1.3.1</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency>
</dependencies>

同一环境1.5.7.RELEASE版本的Spring-boot会抛Caused by: java.lang.IllegalStateException: Cannot load driver class: com.mysql.jdbc.Driver异常,1.5.6.RELEASE以及1.5.5.RELEASE版本亲测没问题

application.properties配置文件

#数据库
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/test
spring.datasource.username=root
spring.datasource.password=741852
spring.datasource.driver-class-name=com.mysql.jdbc.Driver#mybatis&&通用Mapper
mybatis.type-aliases-package=com.karle.bean
mybatis.mapper-locations=classpath:mapper/*.xml
mapper.mappers=com.karle.tk.TkMapper
mapper.identity=MYSQL#分页插件
pagehelper.helperDialect=mysql
pagehelper.reasonable=true
pagehelper.supportMethodsArguments=true
pagehelper.params=count=countSql#log
logging.file=logger.log
logging.level.*=debug

映射实体(省略字段get、set)

import java.util.Date;import javax.persistence.Column;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;@Table(name = "user")
public class User {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Integer id;/*** 名称*/@Column(name = "name")private String name;/*** 年龄*/@Column(name = "age")private Integer age;/*** 身份编号*/@Column(name = "card_no")private Integer cardNo;/*** 生日*/@Column(name = "birthday")private Date birthday;
}

本地通用Mapper接口(继承通用Mapper接口)

import tk.mybatis.mapper.common.Mapper;
import tk.mybatis.mapper.common.MySqlMapper;public interface TkMapper<T> extends Mapper<T>, MySqlMapper<T> {}

Mapper接口:基本的增、删、改、查方法
MySqlMapper:针对MySQL的额外补充接口,支持批量插入

业务接口(继承“本地通用Mapper接口”)

import org.apache.ibatis.annotations.Param;import com.karle.bean.User;
import com.karle.tk.TkMapper;public interface UserMapper extends TkMapper<User> {public User selectByCardNo(@Param("cardNo") int cardNo);}

Spring-boot启动类,@MapperScan仅扫描业务接口包,不能扫描本地通用Mapper接口包,否则报java.lang.ClassCastException: sun.reflect.generics.reflectiveObjects.TypeVariableImpl cannot be cast to java.lang.Class异常

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
@MapperScan(basePackages = { "com.karle.mapper" })
public class SpringBootMyBatisApplication {public static void main(String[] args) {SpringApplication.run(SpringBootMyBatisApplication.class, args);}}

通过使用@MapperScan可以指定要扫描的Mapper类的包的路径,比如:

@SpringBootApplication
@MapperScan("com.kfit.*.mapper")
public class App {  public static void main(String[] args) {  SpringApplication.run(App.class, args);  }
}

或者:

@SpringBootApplication
@MapperScan("com.kfit.mapper")
public class App {  public static void main(String[] args) {  SpringApplication.run(App.class, args);  }
}

可以根据包的结构指定不同的表达式。

使用@MapperScan注解多个包

可以使用如下的方式指定多个包:

@SpringBootApplication
@MapperScan({"com.kfit.demo","com.kfit.user"})
public class App {  public static void main(String[] args) {  SpringApplication.run(App.class, args);  }
}

如果mapper类没有在Spring Boot主程序可以扫描的包或者子包下面,可以使用如下方式进行配置:

@SpringBootApplication
@MapperScan({"com.kfit.*.mapper","org.kfit.*.mapper"})
public class App {  public static void main(String[] args) {  SpringApplication.run(App.class, args);  }
}  

单元测试

import java.util.ArrayList;
import java.util.Date;
import java.util.List;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 com.github.pagehelper.PageHelper;
import com.karle.bean.User;
import com.karle.mapper.UserMapper;@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringBootMyBatisApplicationTests {@Autowiredprivate UserMapper mapper;// 插入一条新记录@Testpublic void insertOne() {User newUser = new User();int cardNo = (int) (Math.random() * 10000000);newUser.setAge(24);newUser.setBirthday(new Date());newUser.setName(cardNo + "用户");newUser.setCardNo(cardNo);mapper.insertSelective(newUser);System.out.println("插入成功");}// 批量插入记录@Testpublic void insertMore() {List<User> recordList = new ArrayList<User>();for (int i = 0; i < 2; i++) {User newUser = new User();int cardNo = (int) (Math.random() * 10000000);newUser.setAge(26);newUser.setBirthday(new Date());newUser.setName(cardNo + "批量插入用户");newUser.setCardNo(cardNo);recordList.add(newUser);}mapper.insertList(recordList);System.out.println("批量插入成功");}// 根据唯一编号查询用户(通用Mapper查询)@Testpublic void selectByCardNo() {User paramBean = new User();paramBean.setCardNo(6647403);User dbUser = mapper.selectOne(paramBean);if (dbUser != null) {System.out.println("数据库用户(通用Mapper查询):" + dbUser.getName());return;}System.out.println("查无此用户");}// 根据唯一编号查询用户(XML查询)@Testpublic void selectByCardNoByXml() {User dbUser = mapper.selectByCardNo(6105967);if (dbUser != null) {System.out.println("数据库用户(XML查询):" + dbUser.getName());return;}System.out.println("查无此用户");}// 根据年龄查询一组用户@Testpublic void selectByAge() {User paramBean = new User();paramBean.setAge(24);List<User> dbUserList = mapper.select(paramBean);System.out.println("总共查询数:" + dbUserList.size());}// 分页查询用户@Testpublic void selectByPage() {PageHelper.offsetPage(1, 5);List<User> dbUserList = mapper.select(null);for (User item : dbUserList) {System.out.println("分页用户:" + item.getName());}}// 更新用户信息@Testpublic void updateOneInfo() {User paramBean = new User();paramBean.setId(1);paramBean.setAge(26);mapper.updateByPrimaryKeySelective(paramBean);System.out.println("更新成功");}}

事务的使用

spring Boot 使用事务非常简单,首先使用注解 @EnableTransactionManagement开启事务支持后,然后在访问数据库的Service方法上添加注解 @Transactional 便可。

@EnableTransactionManagement放在启动类上

springboot---mybits整合相关推荐

  1. Docker 部署 SpringBoot 项目整合 Redis 镜像做访问计数Demo

    Docker 部署SpringBoot项目整合 Redis 镜像做访问计数Demo 最终效果如下 大概就几个步骤 1.安装 Docker CE 2.运行 Redis 镜像 3.Java 环境准备 4. ...

  2. springboot+security整合(1)

    说明 springboot 版本 2.0.3 源码地址:点击跳转 系列 springboot+security 整合(1) springboot+security 整合(2) springboot+s ...

  3. SpringBoot服务整合(整合邮件服务、定时调度、Actuator监控)

    在进行项目开发的时候经常会遇见以下的几个问题:需要进行邮件发送.定时的任务调度.系统的监控处理,实际上这些操 作都可以通过 SpringBoot 进行整合操作.2.1.SpringBoot 整合邮件服 ...

  4. springboot下整合各种配置文件

    本博是在springboot下整合其他中间件,比如,mq,redis,durid,日志...等等  以后遇到再更.springboot真是太便捷了,让我们赶紧涌入到springboot的怀抱吧. ap ...

  5. springboot项目整合mybatis

    SpringBoot项目整合mybatis 本章内容 使用 idea创建 SpringBoot项目 SpringBoot项目中配制 mybatis 框架 1 创建 SpringBoot项目 1.1 在 ...

  6. SpringBoot系列九:SpringBoot服务整合(整合邮件服务、定时调度、Actuator监控)

    声明:本文来源于MLDN培训视频的课堂笔记,写在这里只是为了方便查阅. 1.概念:SpringBoot 服务整合 2.背景 在进行项目开发的时候经常会遇见以下的几个问题:需要进行邮件发送.定时的任务调 ...

  7. SpringBoot项目整合Retrofit最佳实践,这才是最优雅的HTTP客户端工具!

    作者:六点半起床 juejin.im/post/6854573211426750472 大家都知道okhttp是一款由square公司开源的java版本http客户端工具.实际上,square公司还开 ...

  8. SpringBoot 2 整合 Spring Session 最简操作

    SpringBoot 2 整合 SpringSession 前言 Spring Session 介绍 SpringBoot 快速整合 Spring Session Spring Session 测试 ...

  9. SpringBoot+Swagger整合API

    SpringBoot+Swagger整合API Swagger:整合规范的api,有界面的操作,测试 1.在pom.xml加入swagger依赖 <!--整合Swagger2配置类-->& ...

  10. springboot+Vue整合Luckysheet,实现在线编辑Excel表格

    springboot+Vue整合Luckysheet,实现在线编辑Excel表格 功能:页面嵌入Luckysheet表格组件,能够在线编辑Excel表格,实现表格的读取,保存功能(不支持导出为xls文 ...

最新文章

  1. 2021高考成绩一分段查询陕西省,2021年陕西高考一分一段表查询排名方法 成绩排名位次什么时候公布...
  2. Spring@Cacheable注解在类内部调用失效的问题
  3. android自定义dialog开源库,android-dialog: 此框架提供五种对话框的显示,并支持对话框的扩展,目的是为了提供对话框的统一管理,并提供对话框显示的公共接口。...
  4. 反向代理与Real-IP和X-Forwarded-For(转)
  5. ADSL提速 从入门到精通
  6. erlang lists模块函数使用大全
  7. Web前端新手一定要知道的几个框架!
  8. java 获得 加载类_java 类的加载,与获得相应的方法
  9. python列表count()函数
  10. java实现rabbitmq路由模型(routing/topic queues), 生产者 消费者 交换机 消息队列
  11. PCB SI9000阻抗计算引擎Web方式实现方法
  12. Python实现双色球随机选号
  13. Android驱动开发过程中常用的adb指令
  14. SAN(存储区域网络),WWN, WWPN,WWNN区别
  15. 中国行政区划代码,包括五级行政区划详细代码,县级以上区划地理围栏
  16. Aqua Comms携手Ciena 测试海底光缆网络150Gbps波长传输
  17. cpp-http 库的使用
  18. matlab字号单位是磅吗,Office软件中字体“号”与“磅”的关系
  19. Android五子棋开发实验报告,Android五子棋游戏实验报告.doc
  20. teradata中no more spool space

热门文章

  1. OpenGL样板程序,会转动的正方形
  2. linux 查找文件夹_用python打造一个基于socket的文件(夹)传输系统
  3. 视频图像处理平台对比_对比传统智能结算,戈子视觉结算有了质的改变
  4. 武汉计算机985211大学有哪些,武汉985211大学有哪些 武汉985211大学有什么
  5. Unity SRP自定义渲染管线 -- 5.Directional Shadows
  6. caffe 框架梳理(待续)
  7. TypeScript类型检查机制
  8. JS,JQ 格式化小数位数
  9. 您的浏览器没有获得Java Virtual Machine(JVM)支持。可能由于没有安装JVM或者已安装但是没有启用。请安装JVM1.5或者以上版本,如果已安装则启用它。...
  10. rank()over 函数的使用