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(一):跑起来的更多相关文章

  1. SpringBoot整合Mybatis之项目结构、数据源

    已经有好些日子没有总结了,不是变懒了,而是我一直在奋力学习springboot的路上,现在也算是完成了第一阶段的学习,今天给各位总结总结. 之前在网上找过不少关于springboot的教程,都是一些比 ...

  2. SpringBoot整合Mybatis【非注解版】

    接上文:SpringBoot整合Mybatis[注解版] 一.项目创建 新建一个工程 ​ 选择Spring Initializr,配置JDK版本 ​ 输入项目名 ​ 选择构建web项目所需的state ...

  3. 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 ...

  4. springboot学习随笔(四):Springboot整合mybatis(含generator自动生成代码)

    这章我们将通过springboot整合mybatis来操作数据库 以下内容分为两部分,一部分主要介绍generator自动生成代码,生成model.dao层接口.dao接口对应的sql配置文件 第一部 ...

  5. springboot整合mybatis出现的一些问题

    springboot整合mybatis非常非常的简单,简直简单到发指.但是也有一些坑,这里我会详细的指出会遇到什么问题,并且这些配置的作用 整合mybatis,无疑需要mapper文件,实体类,dao ...

  6. springBoot整合mybatis、jsp 或 HTML

    springBoot整合mybatis.jsp Spring Boot的主要优点: 1:  为所有Spring开发者更快的入门: 2:  开箱即用,提供各种默认配置来简化项目配置: 3:  内嵌式容器 ...

  7. SpringBoot系列七:SpringBoot 整合 MyBatis(配置 druid 数据源、配置 MyBatis、事务控制、druid 监控)

    1.概念:SpringBoot 整合 MyBatis 2.背景 SpringBoot 得到最终效果是一个简化到极致的 WEB 开发,但是只要牵扯到 WEB 开发,就绝对不可能缺少数据层操作,所有的开发 ...

  8. SpringBoot整合Mybatis完整详细版二:注册、登录、拦截器配置

    接着上个章节来,上章节搭建好框架,并且测试也在页面取到数据.接下来实现web端,实现前后端交互,在前台进行注册登录以及后端拦截器配置.实现简单的未登录拦截跳转到登录页面 上一节传送门:SpringBo ...

  9. SpringBoot整合Mybatis完整详细版

    记得刚接触SpringBoot时,大吃一惊,世界上居然还有这么省事的框架,立马感叹:SpringBoot是世界上最好的框架.哈哈! 当初跟着教程练习搭建了一个框架,传送门:spring boot + ...

随机推荐

  1. Redis学习二(数据操作).

    key 操作 删除 key:del key 批量删除key:redis-cli -a(密码)keys "QXJ_*"| xargs redis-cli -a(密码)del 查看所有 ...

  2. 设置openwrt路由器的防火墙_允许从外网访问内网的ipv6服务

    设置openwrt路由器的防火墙_允许从外网访问内网的ipv6服务 转载注明来源: 本文链接 来自osnosn的博客,写于 2019-11-02. 参考文章: IPv6"内网"设备 ...

  3. Spring cloud Feign 深度学习与应用

    简介 Spring Cloud Feign是一个声明式的Web Service客户端,它的目的就是让Web Service调用更加简单.Feign提供了HTTP请求的模板,通过编写简单的接口和插入注解 ...

  4. C# 使用TopShelf实现Windows服务部署

    一.TopShelf介绍 topShelf是创建Windows服务的一种方式,可以方便管理应用服务,最大广泛应用于,数据实时接收,定时推送等. 二.TopShelf使用 1.安装 TopShelf程序 ...

  5. PlayJava Day023

    进程:进程是程序的一次动态执行过程,它经历了从代码加载.执行到执行完毕的一个完整过程,这个过程也是进程本身从产生.到发展到最终消亡的过程 多进程:多进程操作系统能同时运行多个进程(程序) 多线程:是指 ...

  6. How to: Implement a Custom Base Persistent Class 如何:实现自定义持久化基类

    XAF ships with the Business Class Library that contains a number of persistent classes ready for use ...

  7. 12.2新特性 使用DBCA duplicate创建物理备用数据库 (Doc ID 2283697.1)

    Creating a Physical Standby database using DBCA duplicate (Doc ID 2283697.1) APPLIES TO: Oracle Data ...

  8. PS各种行业文件创建

    ps可以运用于:印刷.喷绘.网络等行业. 印刷 创建的印刷文件需要修改为毫米为单位,分辨率300以上,CMYK颜色格式: 16开的尺寸为:210*285mm:但在印刷之后,剪裁需要留出出血位,上下左右 ...

  9. centos7.6 jumpserver 堡垒机 重启启动顺序

    cd /sdata/usr/local python3. -m venv py3 source /sdata/usr/local/py3/bin/activate cd /sdata/usr/loca ...

  10. [译]Vulkan教程(13)图形管道基础之Shader模块

    [译]Vulkan教程(13)图形管道基础之Shader模块 Shader modules Unlike earlier APIs, shader code in Vulkan has to be s ...