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. STM32基本GPIO操作:按键输入(扫描+外部中断)

    (涉及专有名词较多,难免解释不到位,若有错误还请指出,谢谢!) 硬件连接图如下: 一.扫描 思路是在main函数中通过死循环来扫描端口电平状态检测,以此判断按键是否按下.实现较为简单. 1.初始化(注 ...

  2. 让 Lua 访问数据库

    Lua 自身并没有提供访问数据库的函数,但是借助外部扩展库我们可以很容易实现对数据库的各种操作,下面就为大家介绍这样一个扩展库 - LuaSQL,你可以在下载区得到它. LuaSQL 定义了一套简单的 ...

  3. golang的make

    golang 分配内存主要有内置函数new和make,今天我们来探究一下make有哪些玩法. map只能为slice, map, channel分配内存,并返回一个初始化的值.首先来看下make有以下 ...

  4. Linux.centos安装mysql5.7.18

    一:删除已有的mysql步骤 1 卸载旧的mysql 1.1 查询有哪些mysql文件 [root@zookeeper init.d]# find / -name mysql /var/lock/su ...

  5. 秒杀系统(一)----环境搭建及集成Mybatis、Redis

    1.1 环境搭建--pom文件 <?xml version="1.0" encoding="UTF-8"?> <project xmlns=& ...

  6. FCC---CSS Flexbox: Add Flex Superpowers to the Tweet Embed

    To the right is the tweet embed that will be used as the practical example. Some of the elements wou ...

  7. HTML基础——基础标签

    一.HTML概述 htyper text markup language  即超文本标记语言. 超文本: 就是指页面内可以包含图片.链接,甚至音乐.程序等非文字元素. 标记语言: 标记(标签)构成的语 ...

  8. 从零开始学vuejs

    最近一段时间都花在了学习vue上,还总是断断续续的,学习的效果不是很明显,思考了好久了,应该是没有进行一个系统的总结,导致很多知识点总是似是而非,而且也有一部分是思维还没有从java转变过来,废话不多 ...

  9. 设置自动获取IP和DNS

    问题阐述 设置ipv4的自动获取时遇到一个问题,ip和dns自动获取可以确认设置,但是全局时就是报错,回头去看ipv4的ip和dns也还是原来的样子 由于一直使用的都是自动获取,很少会有主动设置ip或 ...

  10. php7深入理解匿名函数和回调函数

    匿名函数是没有名称的函数,可以将函数赋值给变量,再调用使用,回调函数是指作为一个参数值传值另外一个函数使用的函数. //匿名函数 没名称的函数 $a=function (){echo "ww ...