SpringBoot整合Mybatis非注解版
Posted cuiyanan
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringBoot整合Mybatis非注解版相关的知识,希望对你有一定的参考价值。
一、项目创建
- 新建一个工程
- 选择Spring Initializr,配置JDK版本
- 输入项目名
- 选择构建web项目所需的staters(启动器)
- 选择与数据库相关的组件
分析:Spring Boot基本上将我们实际项目开发中所遇到的所有场景都做了封装。它将所有的功能场景都抽取出来,做成了一个个的staters(启动器),只需要在项目的pom.xml配置文件里面引入这些starter相关场景的所有依赖都会导入进来。需要什么功能就导入什么场景的启动器,实质就是通过配置导入了与实现其功能相关的jar包,然后直接进行项开发即可。
- 选择保存地址后点击Finish
- 注意:idea必须在联网环境下才会自动构建项目
- 在项目中使用druid作为数据源,不会的请点击SpringBoot整合Druid数据源
- 在bean包下新建实体类对象Employee(员工)
- 新建数据库mybatis,在数据库中新建与实体类对象相关联的数据库表 employee
DROP TABLE IF EXISTS `employee`; CREATE TABLE `employee` ( `id` int(11) NOT NULL AUTO_INCREMENT, `lastName` varchar(255) DEFAULT NULL, `email` varchar(255) DEFAULT NULL, `gender` int(2) DEFAULT NULL, `d_id` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
- 在mapper包下新建与实体类所关联的mapper接口【非注解版】:EmployeeMapper
- 在classpath:mybatis/下新建mybatis的主配置文件:mybatis-config.xml
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <!--切记:要将此映射文件与相对应的mapper接口通过namespace属性进行关联--> <mapper namespace="com.cyn.mapper.EmployeeMapper"> <!-- public Employee getEmpById(Integer id); public void insertEmp(Employee employee);--> <select id="getEmpById" resultType="com.cyn.bean.Employee"> SELECT * FROM employee WHERE id=#{id} </select> <insert id="insertEmp"> INSERT INTO employee(lastName,email,gender,d_id) VALUES (#{lastName},#{email},#{gender},#{dId}) </insert> </mapper>
- 在application.yml(application.properties)项目配置文件中指定mybatis的主配置文件和mapper映射文件的路径,告知springboot,完整application.yml配置文件如下:
spring: datasource: username: root password: 123456 url: jdbc:mysql://localhost:3306/mybatis driver-class-name: com.mysql.jdbc.Driver #修改springboot默认数据源为Druid type: com.alibaba.druid.pool.DruidDataSourceC3P0Adapter #数据源其他配置 initialSize: 5 minIdle: 5 maxActive: 20 maxWait: 60000 timeBetweenEvictionRunsMillis: 60000 minEvictableIdleTimeMillis: 300000 validationQuery: SELECT 1 FROM DUAL testWhileIdle: true testOnBorrow: false testOnReturn: false poolPreparedStatements: true #配置监控统计拦截的filters,去掉后监控界面sql无法统计,‘wall‘用于防火墙 filters: stat,wall,log4j maxPoolPreparedStatementPerConnectionSize: 20 useGlobalDataSourceStat: true connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500 #配置mybatis的主配置文件和mapper映射文件的路径 mybatis: config-location: classpath:mybatis/mybatis-config.xml mapper-locations: classpath:mybatis/mapper/*.xml
- 在controller包下新建controller控制类:EmpController
- @RestController:等价于同时使用@ResponseBody和@Controller
- @GetMapping("/emp/{id}"):等价于@RequestMapping(value = "/dept/{id}",method = RequestMethod.GET)
- /emp/{id}:controller中的url采用restful形式,不会的请自行百度
- @PathVariable("id"):将url中相对应参数名的值绑定到指定的形参上
- 最终项目结构目录如下:
二、项目测试
- 启动项目,在url地址栏输入插入操作:http://localhost:8080/emp?lastName=AAA&[email protected]&gender=1
- 观察数据库,看是否插入成功
- 再在url地址栏输入查询操作:http://localhost:8080/emp/1
- 至此,springboot整合mybatis成功!如果你失败了,继续调试吧骚年!刚搬来博客园,请多多关照手动滑稽--
( ̄︶ ̄)↗[GO!]
以上是关于SpringBoot整合Mybatis非注解版的主要内容,如果未能解决你的问题,请参考以下文章
SpringBoot整合Mybatis方式2:使用注解方式整合Mybatis
Java之Spring Boot入门到精通IDEA版SpringBoot整合其他框架Junit,Redis,MyBatis(一篇文章精通系列)中