二、springBoot 整合 mybatis 项目实战
前言
上一篇文章开始了我们的springboot序篇,我们配置了mysql数据库,但是我们sql语句直接写在controller中并且使用的是jdbcTemplate。项目中肯定不会这样使用,上篇文章也说了,会结合mybatis 或者JPA 使用。我们这篇文章就来结合 mybatis 来使用吧,至于为什么选mybatis 而不是JPA ,这个看个人洗好吧。然后这篇文章会附带一讲一下今天为项目新增的配置。主要是为了保持项目和文章的一致性。
先贴出我们今天项目的结构吧,和昨天贴出来的差不多,在那基础上添加了一些东西,整个框架的模型算是成型了。

引入mybatis依赖
一般改动都是从pom.xml 开始的,我们在昨天基础上的pom.xml 文件中加上mybatis 依赖,版本自己选吧。
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.0.0</version>
 </dependency>
Entry层
昨天我们创建了一个user表 并插入了一条数据,我们就先用这张表吧,所以我们在entry 包中创建一个UserEntry 的实体类.
代码如下:
@Getter
@Setter
public class UserEntry {
    private int id;
    private String userName;
    private String password;
    private String email;
    private String roleCode;
    private String roleName;
    private String gmtCreate;
    private String gmtUpdate;
    private String nickname;
    private String userCreate;
}
可以看到这里用的注解和@Getter 和@Setter。这里就是避免代码中写入过多的get和 set 方法,使得代码变得更加简洁。
Dao 层
Dao是用来处理数据的,这里我们引入了mybatis ,可以使用注解,也可以创建xml 文件,将sql 语句写在xml 文件中。我们这里就采用注解的方式吧,毕竟我们springboot项目,不想再出现xml配置文件了(后期也说不定哈哈)。
在dao包下创建一个userMapper 接口。代码如下:
@Mapper
public interface UserMapper {
    @Select("select id,username as userName,password,email,role_code as roleCode,gmt_create as gmtCreate,gmt_update as gmtUpdate,nickname as nickName,user_create as userCreate from sys_user")
    List<UserEntry> findUserList();
    @Insert({"insert into sys_user(username,password,email) values('${user.userName}','${user.password}','${user.email}')"})
    int add(@Param("user") UserEntry user);
    @Delete("delete from sys_user where id = #{id}")
    int delete(int id);
}
我们这里就先写一个查询、删除和插入的方法吧。可以看到,在接口上引入@Mapper 注解,然后就可以直接使用@Select 和@Insert 等注解啦,直接把注解sql 语句写在这里面就可以了。
Service 层
service层我们一般都以一个接口和一个实现接口的具体类。
service 接口
代码如下:
public interface UserService {
    List<UserEntry> findUserList();
    int addUser(String userName,String password,String email);
    int deleteUser(int id);
}
serviceImpl 具体实现类。
在service 包的impl 包创建 UserServiceImpl 类。代码如下:
@Service
public class UserServiceImpl implements UserService {
    @Autowired
    protected UserMapper userMapper;
    @Override
    public List<UserEntry> findUserList() {
        return userMapper.findUserList();
    }
    @Override
    public int addUser(String userName, String password, String email) {
        UserEntry user=new UserEntry();
        user.setUserName(userName);
        user.setPassword(password);
        user.setEmail(email);
        return userMapper.add(user);
    }
    @Override
    public int deleteUser(int id) {
        return userMapper.delete(id);
    }
}
controller 层
我们在controller 包下的userinfo 包下创建UserController 类。代码如下:
@Slf4j
@RestController
@RequestMapping("/user")
public class UserController {
    @Autowired
    private UserService userService;
    @RequestMapping(value = "/list",method = RequestMethod.GET)
    public List<UserEntry> findUserList(){
        return userService.findUserList();
    }
    @RequestMapping(value = "/add",method = RequestMethod.GET)
    public String addUser(@RequestParam(value = "userName")String uaserName,@RequestParam(value = "password")String password,@RequestParam(value = "email")String email){
        int falg=userService.addUser(uaserName,password,email);
        if(falg>0){
            return "success";
        }
        return "error";
    }
    @RequestMapping(value = "/delete",method = RequestMethod.GET)
    public String deleteUser(@RequestParam(value = "id")int id){
        if(userService.deleteUser(id)>0){
            return "success";
        }
        return "error";
    }
}
测试
好了,万事具备,来测试吧。我们启动项目后,在浏览器输入
添加一个用户
http://localhost:9090/zlflovemm/user/add?userName=qaz&password=123456&email=123@qq.com

查询所有用户
http://localhost:9090/zlflovemm/user/list

删除一个用户
http://localhost:9090/zlflovemm/user/delete?id=19

都没有问题啦,说明基本的增删改查整合 mybatis 都是可行的。
配置多环境文件
好了,大头讲完了,我们现在来讲讲项目今天进行了哪些配置。首先我们来看下我们项目中多了好几个配置文件。

分别对应的是开发环境,测试环境,生产环境。毕竟我们在实际开发过程中,这三个环境都是经常有用到的,总会有数据库连接改来改去的问题。这里直接配置多份,想用哪个用那个就可以了。避免反复改容易出错的问题。
我这里就暂时把连接mysql 的链接放到不同环境了。
先在application.properties中加入
spring.profiles.active=dev
表示用的是开发环境,就会读取application-dev.yml 文件中的配置。
application-dev.xml文件内容如下,另外两个文件也差不多,就不贴出来了。

配置日志
项目中怎么能缺乏日志文件呢,我这里用的springboot 自带的日志框架logback 也很方便。我们先在application.properties 中加入
#日志配置
logging.level.org.springframework.web=info
logging.config=classpath:logback.xml
debug=true
然后在 application.properties 同目录下创建一个 logback.xml.内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">
    <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->
    <property name="LOG_HOME" value="./logs" />
    <property name="INFO_FILE" value="zlflovemm_log" />
    <property name="ERROR_FILE" value="zlflovemm_error" />
    <!--控制台日志, 控制台输出 -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度,%msg:日志消息,%n是换行符-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
        </encoder>
    </appender>
    <!-- 文件保存日志的相关配置,同步 -->
    <appender name="FILE"  class="ch.qos.logback.core.rolling.RollingFileAppender">
        <Prudent>true</Prudent>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--日志文件输出的文件名-->
            <FileNamePattern>
                ${LOG_HOME}/${INFO_FILE}-%d{yyyy-MM-dd}.log
            </FileNamePattern>
            <!--日志文件保留天数-->
            <MaxHistory>30</MaxHistory>
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS}[%t][%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
        <!--日志文件最大的大小-->
        <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
            <MaxFileSize>10MB</MaxFileSize>
        </triggeringPolicy>
    </appender>
    <!-- 文件保存日志的相关配置,同步 -->
    <appender name="ERROR"  class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level>
        </filter>
        <Prudent>true</Prudent>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--日志文件输出的文件名-->
            <FileNamePattern>
                ${LOG_HOME}/${ERROR_FILE}-%d{yyyy-MM-dd}.log
            </FileNamePattern>
            <!--日志文件保留天数-->
            <MaxHistory>30</MaxHistory>
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS}[%t][%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
        <!--日志文件最大的大小-->
        <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
            <MaxFileSize>10MB</MaxFileSize>
        </triggeringPolicy>
    </appender>
    <!-- 日志输出级别 -->
    <root level="INFO">
        <appender-ref ref="STDOUT" />
        <appender-ref ref="FILE"/>
        <appender-ref ref="ERROR" level="error" />
    </root>
</configuration>
这样项目日志就配置好了,至于日志的具体配置,修改logback.xml 里面参数就可以了。和log4g差不多。
配置banner
最后既然是一个项目,当然得有点标志性的东西,比如logo。springboot 给我们留下了一个彩蛋就是banner。我们可以在项目启动的时候,显示我们独一无二的logo .
在application.properties 同目录下创建 banner.txt

艺术字大家在网上自行搜索,这里就不推荐啦哈哈。这样我们在项目启动的时候就会加载我们的logo. 算是给广大的我们一点福利吧。
番外
今晚总算是写完了,本来会早点的,但是不知道怎么就弄这么晚了。
今天项目的代码也同步到github 上啦。
github地址:https://github.com/QuellanAn/zlflovemm
后续加油♡
欢迎大家关注个人公众号 "程序员爱酸奶"
分享各种学习资料,包含java,linux,大数据等。资料包含视频文档以及源码,同时分享本人及投递的优质技术博文。
如果大家喜欢记得关注和分享哟❤

二、springBoot 整合 mybatis 项目实战的更多相关文章
- springBoot 整合 mybatis 项目实战
		二.springBoot 整合 mybatis 项目实战 前言 上一篇文章开始了我们的springboot序篇,我们配置了mysql数据库,但是我们sql语句直接写在controller中并且使用 ... 
- SpringBoot从入门到精通二(SpringBoot整合myBatis的两种方式)
		前言 通过上一章的学习,我们已经对SpringBoot有简单的入门,接下来我们深入学习一下SpringBoot,我们知道任何一个网站的数据大多数都是动态的,也就是说数据是从数据库提取出来的,而非静态数 ... 
- springboot+springmvc+mybatis项目整合
		介绍: 上篇给大家介绍了ssm多模块项目的搭建,在搭建过程中spring整合springmvc和mybatis时会有很多的东西需要我们进行配置,这样不仅浪费了时间,也比较容易出错,由于这样问题的产生, ... 
- SpringBoot整合Mybatis之项目结构、数据源
		已经有好些日子没有总结了,不是变懒了,而是我一直在奋力学习springboot的路上,现在也算是完成了第一阶段的学习,今天给各位总结总结. 之前在网上找过不少关于springboot的教程,都是一些比 ... 
- springboot整合mybatis,redis,代码(二)
		一 说明: springboot整合mybatis,redis,代码(一) 这个开发代码的复制粘贴,可以让一些初学者直接拿过去使用,且没有什么bug 二 对上篇的说明 可以查看上图中文件: 整个工程包 ... 
- SpringBoot整合Mybatis完整详细版二:注册、登录、拦截器配置
		接着上个章节来,上章节搭建好框架,并且测试也在页面取到数据.接下来实现web端,实现前后端交互,在前台进行注册登录以及后端拦截器配置.实现简单的未登录拦截跳转到登录页面 上一节传送门:SpringBo ... 
- SpringBoot 2.x (9):整合Mybatis注解实战
		SSM框架再熟悉不过了,不过以前通常是使用XML写SQL语句 这里用SpringBoot整合Mybatis并且使用注解进行开发 依赖: <!-- Mybatis --> <depen ... 
- SpringBoot整合Mybatis关于分页查询的方法
		最近公司在用到SpringBoot整合Mybatis时当web端页面数据增多时需要使用分页查询以方便来展示数据.本人对分页查询进行了一些步骤的总结,希望能够帮助到有需要的博友.如有更好的方式,也希望评 ... 
- SpringBoot整合Mybatis【非注解版】
		接上文:SpringBoot整合Mybatis[注解版] 一.项目创建 新建一个工程  选择Spring Initializr,配置JDK版本  输入项目名  选择构建web项目所需的state ... 
随机推荐
- 《深入理解Java虚拟机》- Java虚拟机是如何加载Java类的?
			Java虚拟机是如何加载Java类的? 这个问题也就是面试常问到的Java类加载机制.在年初面试百战之后,菜鸟喜鹊也是能把这流程倒背如流啊!但是,也只是字面上的背诵,根本就是像上学时背书考试一样. ... 
- CSV Data Set Config 拓展开发
			1.目的 在日常的性能测试项目中,经常会遇到参数化的问题,我们所熟知的LR工具对参数化支持非常友好,然而JMeter相对逊色一些.大家都知道在使用JMeter工具参数化时常用CSV Data Set ... 
- Ubuntu下安装php7.1的gd,mysql,pdo_mysql扩展库
			执行以下命令 # apt-get install php7.1-gd # apt-get install php7.0-mysql 重新启动 php7.1-fpm(因为我是安装的 Nginx 和 ph ... 
- serverless在微店node领域的探索应用
			背景 目前微店中台团队为了满足公司大部分产品.运营以及部分后端开发人员的尝鲜和试错的需求,提供了一套基于图形化搭建的服务端接口交付方案,利用该方案及提供的系统可生成一副包含运行时环境定义可立即运行的工 ... 
- Sqlserver 使用.net查询被事务锁住处理
			在有些应用场景中.事务开了后或能需要再去调用某个DAL读取表中的数据.但DAL里又是新开的链接,由于外面有事务所以这里读的时候就读不到.这种情况下可以在这个DAL的查询里开一个新的事务级别设为允许脏读 ... 
- python实现RSA加密和签名以及分段加解密的方案
			1.前言 很多朋友在工作中,会遇到一些接口使用RSA加密和签名来处理的请求参数,那么遇到这个问题的时候,第一时间当然是找开发要加解密的方法,但是开发给加解密代码,大多数情况都是java,c++,js等 ... 
- Mbatis是什么?怎么运行?
			一 . Mybatis是什么? Mybatis是一个持久层框架,其中编写的过程中sql语句是需要程序员自己去编写,Mybatis也有 一些映射(输入参数映射,输出参数映射),Mybatis是 ... 
- node.js的Promise对象的使用
			Promise对象是干嘛用的? 将异步操作以同步操作的流程表达出来 一.Promise对象的定义 let flag = true; const hello = new Promise(function ... 
- XMLHttpRequest的概述
			XMLHttpRequest的概述 一.前言 XMLHttpRequest 最早是在IE5中以ActiveX组件的形式实现的.非 W3C 标准. 创建XMLHttpRequest对象(由于非标准所以实 ... 
- Unity3D 基于ShadowMap的平滑硬阴影
			前言 传统的ShadowMap在明暗边缘处都会有很难看的锯齿,因此一般得到的结果会比较难看,常规的解决办法都会在使用ShadowMap渲染阴影的时候通过背面剔除把这种缺陷隐藏掉,最后剩下一个影子.但是 ... 
