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 + ...
随机推荐
- Unity Ruby's Adventure 第一步
官方游戏教程:https://learn.unity.com/project/ruby-s-2d-rpg?language=en 鲁比大冒险是一个2D游戏入门教程,涉及动画,特效,UI,瓦片地图,音效 ...
- RDP矢量数据压缩算法
在绘制对象边缘时涉及到了这个算法,记录一下. 该算法递归进行,首先设定一个阈值,在点集的第一个点和最后一个点间拉一条线段,找出剩下的点集中离线段最远的一个点,如果该点到线段的距离小于阈值则舍弃中间的所 ...
- 带你揭秘Shiro(二)
授权流程 1.对subject进行授权,调用方法isPermitted("permission串") 2.SecurityManager执行授权,通过ModularRealmAut ...
- ElementUI table 点击编辑按钮进行编辑实现示例
<!DOCTYPE html> <html > <head> <meta charset="UTF-8"> <meta nam ...
- 解决方案:从网站下载Excel,我的Office 2016,打开excel文件,显示空白
今天在写Excel导出案例demo的时候发现,Excel下载后打开空白,要打开了看到空白后再点击一次打开后才可以显示,效果就如下图所示: 那么我就不能一次打开吗?我找了半天最终在这个博客找到了答案:h ...
- layui table 表格查询无效问题
[热身话题] 在开发的过程中,大量数据的展示大多采用表格的方式,直观,清晰.在这里,我也使用过一些框架Bootstrap.table ,Dev table ,layui table.本次采用的layu ...
- Oracle 11g Dataguard参数详解
https://www.jb51.net/article/52269.htm注:本文译自<Oracle Data Guard 11g Handbook> Page 78 – Page 88 ...
- [日常] linux设置环境变量
比如首先在/etc/profile里面增加这几个环境变量 export PATH=$PATH:/mnt/f/ubuntu/goProject/go/binexport GOROOT=/mnt/f/ub ...
- s3c2440裸机-清bss原理及实现
1.清bss的引入(为什么要清bss) 我们先举个例子: #include "s3c2440_soc.h" #include "uart.h" char g_C ...
- C# Winform更换Webbrowse为WebKit
本人第一次发表博文,内容不精也不是很有水平,请大家多多包涵~ 说到Webbrowser,可能大家都用过这个控件,它默认使用的是旧版本IE内核. 这就导致了一些问题,比如JS的加载不正确,这个问题就足够 ...