Springboot 整合 MyBatis(一):跑起来
0x1 环境
1. 系统:Windows 10
2. IDE:IntelliJ IDEA 2018.3 x64
0x2 创建项目
1.创建一个SpringBoot项目
选择Spring Initailizr >Next

简单配置即可>Next

选择项目所需依赖>Next

选择项目工作空间[随便写]:目录不存在会自动创建 > Next

创建好后,idea就会加载依赖包,并弹出提示,Meven项目需要导入依赖,选择自动导包

等待一会....当右下角没有进度条就说明好了
2. 创建项目结构
这三个文件可以删除

依次创建目录:controller层,domain层(entity),mapper层,query层,service层,创建好就是这样子......

注意:本文不使用application.properties文件 而使用更加简洁的application.yml文件,可能你们已经注意到了项目中有四个 yml文件这是为什么?
因为现在一个项目有好多环境,开发环境,测试环境,准生产环境,生产环境,每个环境的参数不同,所以我们就可以把每个环境的参数配置到 yml文件中
在Spring Boot中多环境配置文件名需要满足application-{profile}.yml的格式,其中{profile}对应你的环境标识,比如:
application.yml:主文件
application-dev.yml:开发环境
application-test.yml:测试环境
application-prod.yml:生产环境
需要加载那个文件就在在 application.yml 文件中通过spring.profiles.active属性来设置,其值对应{profile}值。比如

创建数据库表
CREATE TABLE `user` (
`id` BIGINT(32) NOT NULL AUTO_INCREMENT,
`userName` varchar(32) NOT NULL,
`passWord` varchar(50) NOT NULL,
`realName` varchar(32) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
3. 完善结构
①User.java
package xyz.bit1024.sunny.domain; /**
* @ClassName User
* @Date 2019-06-15 16:14
* @Author xiaozhi
* @Version 1.0.0
* @Since JDK 1.8
* @Description 实体类
*/
public class User {
private Long id;
private String userName;
private String passWord;
private String realName; public Long getId() {
return id;
} public void setId(Long id) {
this.id = id;
} public String getUserName() {
return userName;
} public void setUserName(String userName) {
this.userName = userName;
} public String getPassWord() {
return passWord;
} public void setPassWord(String passWord) {
this.passWord = passWord;
} public String getRealName() {
return realName;
} public void setRealName(String realName) {
this.realName = realName;
} @Override
public String toString() {
return "User{" +
"id=" + id +
", userName='" + userName + '\'' +
", passWord='" + passWord + '\'' +
", realName='" + realName + '\'' +
'}';
}
}
笔者按:在实体类中覆写toString方法有助于查错---<阿里巴巴Java开发手册>
UserMapper.java
package xyz.bit1024.sunny.mapper; import xyz.bit1024.sunny.domain.User; import java.util.List; /**
* @ClassName UserMapper
* @Date 2019-06-15 16:21
* @Author xiaozhi
* @Version 1.0.0
* @Since JDK 1.8
* @Description
*/
public interface UserMapper {
List<User> listAll();
}
UserQuery.java 查询对象
package xyz.bit1024.sunny.query; /**
* @ClassName UserQuery
* @Date 2019-06-15 16:28
* @Author xiaozhi
* @Version 1.0.0
* @Since JDK 1.8
* @Description
*/
public class UserQuery {
}
IUserService.java:接口层,面向接口思想
package xyz.bit1024.sunny.service; import xyz.bit1024.sunny.domain.User; import java.util.List; /**
* @ClassName IUserService
* @Date 2019-06-15 16:17
* @Author xiaozhi
* @Version 1.0.0
* @Since JDK 1.8
* @Description
*/
public interface IUserService { /**
* 全部用户
* @return List<User>
*/
List<User> listAll();
}
在service 层下创建 impl 目录,并在impl目录下面创建 IUserService 实现类并实现覆写父类方法
UserServiceImpl.java
package xyz.bit1024.sunny.service.impl; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import xyz.bit1024.sunny.domain.User;
import xyz.bit1024.sunny.mapper.UserMapper;
import xyz.bit1024.sunny.service.IUserService; import java.util.List; /**
* @ClassName UserServiceImpl
* @Date 2019-06-15 16:19
* @Author xiaozhi
* @Version 1.0.0
* @Since JDK 1.8
* @Description 实现类[业务类]
*/
@Service
public class UserServiceImpl implements IUserService { @Autowired
private UserMapper userMapper; @Override
public List<User> listAll() {
return userMapper.listAll();
}
}
⑥ 在resources 创建mapper目录,并创建 UserMapper.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="xyz.bit1024.sunny.mapper.UserMapper">
<resultMap id="BaseResultMap" type="xyz.bit1024.sunny.domain.User">
<result column="id" jdbcType="BIGINT" property="id" />
<result column="userName" jdbcType="VARCHAR" property="userName" />
<result column="passWord" jdbcType="VARCHAR" property="passWord" />
<result column="realName" jdbcType="VARCHAR" property="realName" />
</resultMap> <sql id="Base_Column_List">
id, userName, passWord, realName
</sql>
<sql id="Base_Column_List_Value">
#{id,jdbcType=Long},
#{userName,jdbcType=VARCHAR},
#{passWord,jdbcType=VARCHAR},
#{realName,jdbcType=VARCHAR}
</sql>
<select id="listAll" resultMap="BaseResultMap">
select <include refid="Base_Column_List"/> from t_user
</select>
</mapper>
UserController.java
package xyz.bit1024.sunny.controller; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import xyz.bit1024.sunny.domain.User;
import xyz.bit1024.sunny.service.IUserService; import java.util.List; /**
* @ClassName UserController
* @Date 2019-06-15 16:16
* @Author xiaozhi
* @Version 1.0.0
* @Since JDK 1.8
* @Description
*/
@RestController
@RequestMapping("/user")
public class UserController { //注入Service对象
@Autowired
private IUserService iUserService; @RequestMapping("/listAll")
public List<User> listAll(){
return iUserService.listAll();
}
}
4 .完善配置
① 配置Mapper扫描包

application-dev.yml

logback.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<property name="LOG_HOME" value="./logs" />
<property name="APP_NAME" value="bit1024" />
<include resource="org/springframework/boot/logging/logback/defaults.xml" />
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{35} - %msg %n</pattern>
<charset>UTF-8</charset>
</encoder>
</appender>
<appender name="infoFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>INFO</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME}/${APP_NAME}.info.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<maxFileSize>10MB</maxFileSize>
<maxHistory>30</maxHistory>
<totalSizeCap>6GB</totalSizeCap>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
<charset>UTF-8</charset>
</encoder>
</appender>
<appender name="warnFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>WARN</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME}/${APP_NAME}.warn.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<maxFileSize>10MB</maxFileSize>
<maxHistory>30</maxHistory>
<totalSizeCap>6GB</totalSizeCap>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
<charset>UTF-8</charset>
</encoder>
</appender>
<appender name="errorFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>ERROR</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME}/${APP_NAME}.error.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<maxFileSize>10MB</maxFileSize>
<maxHistory>30</maxHistory>
<totalSizeCap>6GB</totalSizeCap>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
<charset>UTF-8</charset>
</encoder>
</appender> <!--myibatis日志配置-->
<logger name="xyz.bit1024.sunny.mapper" level="INFO"/>
<logger name="xyz.bit1024" level="DEBUG"/> <!-- 日志输出级别 -->
<root level="INFO">
<appender-ref ref="CONSOLE"></appender-ref>
<appender-ref ref="infoFile"></appender-ref>
<appender-ref ref="warnFile"></appender-ref>
<appender-ref ref="errorFile"></appender-ref>
</root>
</configuration>
构造测试数据
INSERT INTO `springboot`.`t_user` (`id`, `userName`, `passWord`, `realName`) VALUES ('10000001', 'admin', 'admin', '超级管理员');
INSERT INTO `springboot`.`t_user` (`id`, `userName`, `passWord`, `realName`) VALUES ('10000002', 'user1', '123', '用户1');
INSERT INTO `springboot`.`t_user` (`id`, `userName`, `passWord`, `realName`) VALUES ('10000003', 'user2', '123', '用户2');
一切完毕只待测试
使用PostMan测试一波

成功,,完美
采坑:
java.sql.SQLException: The server time zone value '�й���ʱ��' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.
修改配置文件:
url: jdbc:mysql://localhost:3306/springboot?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=UTC 这次的集成就算完了,,有空把登录+shiro也集成
之前也没用过 GitHub :https://gist.github.com/bit1024-404/38f42bef407a7609e324eb00147ec5c1
转载请注明出处!
Springboot 整合 MyBatis(一):跑起来的更多相关文章
- SpringBoot整合Mybatis之项目结构、数据源
已经有好些日子没有总结了,不是变懒了,而是我一直在奋力学习springboot的路上,现在也算是完成了第一阶段的学习,今天给各位总结总结. 之前在网上找过不少关于springboot的教程,都是一些比 ...
- SpringBoot整合Mybatis【非注解版】
接上文:SpringBoot整合Mybatis[注解版] 一.项目创建 新建一个工程 选择Spring Initializr,配置JDK版本 输入项目名 选择构建web项目所需的state ...
- SpringBoot整合Mybatis注解版---update出现org.apache.ibatis.binding.BindingException: Parameter 'XXX' not found. Available parameters are [arg1, arg0, param1, param2]
SpringBoot整合Mybatis注解版---update时出现的问题 问题描述: 1.sql建表语句 DROP TABLE IF EXISTS `department`; CREATE TABL ...
- springboot学习随笔(四):Springboot整合mybatis(含generator自动生成代码)
这章我们将通过springboot整合mybatis来操作数据库 以下内容分为两部分,一部分主要介绍generator自动生成代码,生成model.dao层接口.dao接口对应的sql配置文件 第一部 ...
- springboot整合mybatis出现的一些问题
springboot整合mybatis非常非常的简单,简直简单到发指.但是也有一些坑,这里我会详细的指出会遇到什么问题,并且这些配置的作用 整合mybatis,无疑需要mapper文件,实体类,dao ...
- springBoot整合mybatis、jsp 或 HTML
springBoot整合mybatis.jsp Spring Boot的主要优点: 1: 为所有Spring开发者更快的入门: 2: 开箱即用,提供各种默认配置来简化项目配置: 3: 内嵌式容器 ...
- SpringBoot系列七:SpringBoot 整合 MyBatis(配置 druid 数据源、配置 MyBatis、事务控制、druid 监控)
1.概念:SpringBoot 整合 MyBatis 2.背景 SpringBoot 得到最终效果是一个简化到极致的 WEB 开发,但是只要牵扯到 WEB 开发,就绝对不可能缺少数据层操作,所有的开发 ...
- SpringBoot整合Mybatis完整详细版二:注册、登录、拦截器配置
接着上个章节来,上章节搭建好框架,并且测试也在页面取到数据.接下来实现web端,实现前后端交互,在前台进行注册登录以及后端拦截器配置.实现简单的未登录拦截跳转到登录页面 上一节传送门:SpringBo ...
- SpringBoot整合Mybatis完整详细版
记得刚接触SpringBoot时,大吃一惊,世界上居然还有这么省事的框架,立马感叹:SpringBoot是世界上最好的框架.哈哈! 当初跟着教程练习搭建了一个框架,传送门:spring boot + ...
随机推荐
- day01-day02 初识java、注释、变量、变量命名、基本数据类型
1. 初识java 1) 什么是java java是一门高级的计算机编程语言 2) JDK的安装 2.1) 下载2.2) 安装2.3) 验证 3) 环境变量的配置 3.1) 打开环境变量3.2) 配置 ...
- IT兄弟连 HTML5教程 CSS3属性特效 动画-animation
CSS3属性中有关于制作动画的三个属性:Transform,Transition,Animation.前面已经介绍过Transform和Transition了,这里我们来学习Animation动画.通 ...
- 从零开始的vue学习笔记(五)
单文件组件 Vue.component 来定义全局组件的缺点: 全局定义 (Global definitions) 强制要求每个 component 中的命名不得重复 字符串模板 (String te ...
- 转载 SAP用户权限控制设置及开发
创建用户SU01 事务码:SU01,用户主数据的维护,可以创建.修改.删除.锁定.解锁.修改密码等 缺省:可以设置用户的起始菜单.登录的默认语言.数字显示格式.以及日期和时间的格式设置 参数:SAP很 ...
- python中错误、调试、单元测试、文档测试
错误分为程序的错误和由用户错误的输入引起的错误,此外还有因为各种各样意外的情况导致的错误,比如在磁盘满的时候写入.从网络爬取东西的时候,网络断了.这类错误称为异常 错误处理 普通的错误处理机制就是在出 ...
- DevExpress Applications<3>
Project Template Project Template Information Template Name Template Description Controls and Compon ...
- 【Java并发系列】--Java内存模型
Java内存模型 1 基本概念 程序:代码,完成某一个任务的代码序列(静态概念) 进程:程序在某些数据上的一次运行(动态) 线程:一个进程有一个或多个线程组成(占有资源的独立单元) 2 JVM与线程 ...
- 在Vue中添加css扩展语言sass
npm install vue-loader --save-dev npm install node-sass --save-dev npm install sass-loader --save-de ...
- 苹果_公司开发者账号_注册Apple ID
本文所有网站入口为developer.apple.com 注册Apple ID 注意事项:目前注册信息尽量用拼音或英文,姓名格式正确,记住安全问题,出生日期在18岁以上(小于18岁会出现Sorry,y ...
- [ERR] Node 172.16.6.154:7002 is not empty. Either the node already knows other nodes (check with CLUSTER NODES) or contains some key in database 0.
关于启动redis集群时: [ERR] Node 172.168.63.202:7001 is not empty. Either the nodealready knows other nodes ...