Spring Boot连接数据库,从MySql5.13飞跃到MySql8.0.18的坑

Spring Boot连接数据库,从MySql5.13飞跃到MySql8.0.18的坑

1.驱动名

驱动包用的是:mysql-connector-java-8.0.18.jar

驱动名从之前的:com.mysql.jdbc.Driver

改为: com.mysql.cj.jdbc.Driver

2.时区问题

昨天用MyBatis逆行工程的时候,出现了以下错误:

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

谷歌翻译为:

服务器时区值”Öйú±ê׼ʱ¼ä”无法识别或代表多个时区。如果要利用时区支持,则必须配置服务器或JDBC驱动程序(通过serverTimezone配置属性)以使用更特定的时区值。

解决:

方法一、在Spring Boot配置文件 application.properties连接数据库 url后面拼接: serverTimezone=UTC

spring.datasource.url=jdbc:mysql://localhost:3306/perimetershop?serverTimezone=UTC

发现这样还是不行,还是时区问题,想到会不会是逆行工程连接数据库的url没有添加这个的缘故,我就在逆行工程的xml里面jdbc连接的url后面也添加了serverTimezone=UTC,果然,不报错了。

方法二、在mysql解压文件中, my.ini文件里,[mysqld] 里面加上default-time-zone=’+8:00′即可,这样url后面就可以不用每次都需要拼接 serverTimezone=UTC。

小扩展:UTC:协调世界时,又称世界同一时间,UTC和格林尼治时间是一样的, 北京处于东八区,领先UTC8个小时。

3.逆行工程多生成不需要的文件

使用MyBatis的逆行工程的时候,会多生成一个XXXWithBLOBs.java 的文件,这个文件,我们并不需要(如下图)。这个文件继承了原有的bean文件。

Spring Boot连接数据库,从MySql5.13飞跃到MySql8.0.18的坑

这个文件是什么呢?这个文件里面会包含数据库大字段,例如:text,blob,clob等。

原因是因为MySql字段中有text类型的,网上的解决方法是:

<table domainobjectname="User" tablename="test_user">
    <columnoverride column="address" javatype="java.lang.String" jdbctype="VARCHAR">
</columnoverride></table>

在table标签里声明一个大字段的行

<columnoverride column="address" javatype="java.lang.String" jdbctype="VARCHAR"></columnoverride>

我照网上做了,但是并没有解决我的问题,而且我的数据库表中,并没有text类型的字段。

网友的力量还是挺强大的,在翻阅好几篇博文之后,终于找到了解决方法

解决方法:

  <span class="hljs-tag"><<span class="hljs-name">jdbcConnection</span>
       <span class="hljs-attr">driverClass</span>=<span class="hljs-string">"com.mysql.jdbc.Driver"</span>
       <span class="hljs-attr">connectionURL</span>=<span class="hljs-string">"jdbc:mysql://localhost:3306/perimetershop?serverTimezone=UTC"</span>
       <span class="hljs-attr">userId</span>=<span class="hljs-string">"root"</span>
       <span class="hljs-attr">password</span>=<span class="hljs-string">"root"</span>></span>
        <span class="hljs-tag"><<span class="hljs-name">property</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"nullCatalogMeansCurrent"</span> <span class="hljs-attr">value</span>=<span class="hljs-string">"true"</span> /></span>
  <span class="hljs-tag">jdbcConnection</span>>

在逆向工程jdbc连接标签内,添加

<property name="nullCatalogMeansCurrent" value="true"></property>

看了一下Mybatis的Generator帮助文档,里面有给出答案:

Spring Boot连接数据库,从MySql5.13飞跃到MySql8.0.18的坑

网址:http://mybatis.org/generator/usage/mysql.html

Original: https://www.cnblogs.com/zdh052286/p/12175265.html
Author: 清酒一杯
Title: Spring Boot连接数据库,从MySql5.13飞跃到MySql8.0.18的坑

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/581603/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • tp5,把耗时操作转为队列,queue + redis + supervisor消息推送(队列的执行异步不异步不知道,workman,swoole可以异步)

    添加队列 /** * 发送一个推送 * @param mixed client_id 设备号(字符串/数组) 1 * @param int group 分组(如:1=用户端2=骑手…

    Linux 2023年5月28日
    078
  • find 查询命令 & 正则表达式

    今日内容 find 正则表达式 Linux 三剑客之 grep 内容详细 一、find 按名称或属性查询文件 按名称查询 find [查找目录] [参数] [] 通配符 : * 表…

    Linux 2023年5月27日
    089
  • Dockerfile

    基本结构 Dockerfile 是一个文本格式的配置文件,用户可以使用 Dockerfile 快速创建自定义镜像。 Dockerfile 由一行行命令语句组成,并且支持以 # 开头…

    Linux 2023年6月13日
    091
  • 节约内存:Instagram的Redis实践(转)

    1.M emcached 内存Key-Value Cache Redis 内存数据库 四,节约内存:Instagram的Redis实践 Instagram可以说是网拍App的始祖级…

    Linux 2023年5月28日
    089
  • shell多线程运行程序

    #!/bin/bash function my_cmd(){ sleep 1 } date tmp_fifofile="/tmp/$$.fifo" mkfifo…

    Linux 2023年6月6日
    0105
  • 我叫Mongo,收了「查询基础篇」,值得你拥有

    这是mongo第二篇「查询基础篇」,后续会连续更新6篇 mongodb的文章总结上会有一系列的文章,顺序是先学会怎么用,在学会怎么用好,戒急戒躁,循序渐进,跟着我一起来探索交流。 …

    Linux 2023年6月14日
    0110
  • MobaXterm左侧没有文件列表,没有SCP,不显示文件夹问题处理

    一般情况是你设置的session属性问题,具体做法是右键你的session,选edit session,SSH 如下图: 选择 SFTP protocol 并勾选 Follow S…

    Linux 2023年5月27日
    0133
  • 初探paramiko

    paramiko模块简介 paramiko是基于SSHv2协议开发的,可用于连接远程SSH服务器,通过SSH连接执行远程命令或者文件传输。paramiko支持Python(2.7,…

    Linux 2023年6月7日
    073
  • bootstrap的基础使用

    Bootstrap Bootstrap是Twitter推出的一个用于前端开发的开源工具包。它由Twitter的设计师Mark Otto和Jacob Thornton合作开发,是一个…

    Linux 2023年6月7日
    098
  • 微服务架构项目搭建过程中的Mysql安装和相关问题

    搭建微服务架构的过程中需要使用Mysql数据库,Mysql数据库搭建着实不是一个容易的事情,会碰到各种各样的问题,如果没有一个安装数据库的思路真的很难把数据库安装好,并且掉入到安装…

    Linux 2023年6月14日
    0105
  • Zookeeper集群搭建及原理

    1 概述 1.1 简介 ZooKeeper 是 Apache 的一个顶级项目,为分布式应用提供高效、高可用的分布式协调服务,提供了诸如数据发布/订阅、负载均衡、命名服务、分布式协调…

    Linux 2023年6月13日
    082
  • 【深度学习】ml_collections报错

    在一些源码中,看见了一个导入: import ml_collections 此时会报错,这个包并不是PyTorch的包,同时也非源码中模块 解决办法: pip install ml…

    Linux 2023年6月13日
    075
  • 简单交叉编译学习

    交叉编译 交叉编译是在一个平台上生成另一个平台上的可执行代码。 同一个体系结构可以运行不同的操作系统;同样,同一个操作系统也可以在不同的体系结构上运行。通常是自己的电脑写好代码编译…

    Linux 2023年6月7日
    0116
  • Netty源码解读(四)-读写数据

    读写Channel(READ)的创建和注册 在NioEventLoop#run中提到,当有IO事件时,会调用 processSelectedKeys方法来处理。 当客户端连接服务端…

    Linux 2023年6月7日
    080
  • Docker下部署LNMP黄金架构

    404. 抱歉,您访问的资源不存在。 可能是网址有误,或者对应的内容被删除,或者处于私有状态。 代码改变世界,联系邮箱 contact@cnblogs.com 园子的商业化努力-困…

    Linux 2023年6月7日
    093
  • [云计算]TCA云架构-思维导图

    博客园 :当前访问的博文已被密码保护 请输入阅读密码: Original: https://www.cnblogs.com/Skybiubiu/p/15962992.htmlAut…

    Linux 2023年6月13日
    0124
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球