zoukankan      html  css  js  c++  java
  • SpringBoot整合MyBatis与MySql8.0

    一、前言

    之前已经有一篇文章讨论过SpringBoot整合MyBatis,因而此篇不在重复累赘,本文主要是最新版的SpringBoot2.0与MyBatis、最新MySQL8.0整合过程中遇到的问题进行总结。同时,SpringBoot整合MyBatis中可以不用之前那篇那样繁琐的配置,可以使用application.properties文件进行整合。

    二、application.yml 与 application.properties 加载顺序

    SpringBoot优先加载yml文件,也就是先加载yml文件再加载properties文件。两个文件都可以起到同时配置全局的作用。如果在yml文件中配置了端口为80,在properties文件中配置了8080,那么最后端口是8080,因而properties后加载,覆盖了之前已经配置后的80端口。

    其实 application.yml 文件会被优先加载,
    
    而如果同时存在 application.properties 文件,并且存在相同的配置,
    
    那么则会用 application.properties 文件中的配置覆盖之前的配置;
    
    也就是说哪个文件被最后加载,哪个才具有最高级别,
    
    因为最后的,会覆盖前面所有的。
    --------------------- 
    作者:微wx笑 
    来源:CSDN 
    原文:https://blog.csdn.net/testcs_dn/article/details/79010798 
    版权声明:本文为博主原创文章,转载请附上博文链接!

    三、application.properties示例

    #设置Tomcat端口,默认8080
    server.port=8080
    #设置项目ContextPath
    server.context-path=/
    #设置Tomcat编码
    server.tomcat.uri-encoding=UTF-8
    #设置视图解析器路径
    spring.mvc.view.prefix=/WEB-INF/views/
    #设置视图解析器后缀
    spring.mvc.view.suffix=.jsp
     
    #数据库配置
    spring.datasource.url=jdbc:mysql://localhost:3306/tuzisong?useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true
    spring.datasource.username=root
    spring.datasource.password=F6m3G3j6
    spring.datasource.driver-class-name=com.mysql.jdbc.Driver
     
    #配置.xml文件路径
    mybatis.mapper-locations=classpath:mapper/*.xml
    #配置模型路径
    mybatis.type-aliases-package=cn.copy.model

    MyBatis通过上述两行,便可在Resource的mapper中读取xml文件和对应的实体类,如果数据库使用的MySQL8.0,加载类需要更改,下文有论述。

    如果想了解整体的配置,文件目录结构,详细可以参考该示例的原文:[1]

    四、使用MySQL8.0

    使用MySQL8.0的时候会出现兼容性的问题。

    1、数据库连接工具无法连接[2]

    mysql8.0默认采用caching_sha2_password的加密方式

    第三方客户端基本都不支持这种加密方式,只有自带的命令行支持

    所以需要修改加密方式。在MySQL自带的客户端client中输入如下命令:

    ALTER USER 'username'@'ip_address' IDENTIFIED WITH mysql_native_password BY 'password';
    
    示例:
    ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';

    2、SpringBoot通过jdbc无法连接到MySQL

    先更换最新的jar包(当前最新为2018-09-27,8.0.13),在maven中添加如下依赖:

    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.13</version>
    </dependency>
    

    同时,application.xml中配置文件中应该改为:

    url: jdbc:mysql://localhost:3306/db_test?characterEncoding=utf8&useSSL=false&serverTimezone=UTC&rewriteBatchedStatements=true
     
    driver: com.mysql.cj.jdbc.Driver

    详细内容可以参考文章[3]

    五、后言

    本文需要对SpringBoot与MyBatis有一定的了解,时代在向前,版本在更新,在重新整合的过程中遇到的各种问题,集合各方的观点与解决方案,总结形成此文。

    Reference:

    [1] 阿豆根, Spring Boot+Mybatis+MySql 完整整合教程, https://blog.csdn.net/qq_33768099/article/details/79787215

    [2] https://stackoverflow.com/questions/49194719/authentication-plugin-caching-sha2-password-cannot-be-loaded

    [3] Xanthuim, MySQLNonTransientConnectionException: Could not create connection to database server., https://blog.csdn.net/qq_15003505/article/details/80463174

  • 相关阅读:
    直接插入排序
    简单选择排序
    xml错误: A pseudo attribute name is expecte
    接口, 抽象类
    The hierarchy of the type AudienceAdvice is inconsistent 《spring in action》
    spring配置文件出错解决办法
    Sangfor tester 实习总结
    求一棵树的面积,2014百度开发测试笔试题
    百度2014校招-深圳-开发测试-求最小“不重复数”
    二个数相加,不使用加减乘除
  • 原文地址:https://www.cnblogs.com/ryelqy/p/10104030.html
Copyright © 2011-2022 走看看