详解Mybatis逆向工程中使用Mysql8.0版本驱动遇到的问题

 更新时间:2018年10月10日 13:53:20   作者:Dmego的博客  
今天在使用 8.0.12 版的 mysql 驱动时遇到了各种各样的坑。这篇文章主要介绍了详解Mybatis逆向工程中使用Mysql8.0版本驱动遇到的问题,感兴趣的小伙伴们可以参考一下

前言

今天在使用 8.0.12 版的 mysql 驱动时遇到了各种各样的坑,在使用 JDBC 连接上遇到的问题可以参考我的上一篇博客。我在使用 mybatis 逆向工程生成各种 mapper , pojo , dao 时,遇到了一个困惑我好几个小时的错误,这个错误是

Result Maps collection already contains value for BaseResultMap

产生这个错误可能有各种原因。但是这里我只说我的原因及解决过程。

初步探索

我在网上查阅了大量的博客文章,对于产生这类错误的原因最多的是:生成了多次 mapper , dao 以及 pojo 文件。也就是多次运行了生成这些文件的方法。造成 XXXmapper.xml 中出现了重复的 resultmap 。但是我这里把这些文件删除后,再重新生成还是会报这个错。所以肯定不是多次生成的问题。

于是我打开了出现问题的那个 Mapper.xml 文件,搜索 BaseResultMap 发现其作为 resultMap 的 id 居然出现了三次,还有很多其他的 sql 标签的 id 也有很多重复的。我将这些重复的都删除,再次运行,成功了,没有出现错误。而且利用这些生成的 mapper 做后面的功能也没有任何问题。这就非常奇怪,为什么会多生成这些代码呢,我继续在网上找相关的文章。

深入探索

好不容易找到一篇博客中提到 :升级到 mysql 8.0 驱动后的使用 mybatis 逆向工程生成的文件或不一样,具体的怎么不一样也没有说。看到这里,我猜会不会是驱动版本造成的,于是我将 pom.xml 里的 mysql 驱动版本调整到了 5.1.10。删干净文件,再次生成后,发现之前出错的那个 mapper.xml 里的 以 BaseResultMap 作为 id 的 resultMap 只有一个了,其他的 resultMap 中 id 也是唯一的。为了检验这次生成的到底有没有用。我启动 Tomact 运行程序。发现正常启动,后续的功能也没有问题。

最终解决

但是如果使用 5.0 版本的驱动连接 mysql 8.0 在项目中可能会遇到难以预料的问题,所以我并没有就此将驱动版本改变。我继续在网上通过换各种关键词来搜寻解决方案。几个小时过去了,还是没有任何结果。最后被迫去看了 [MyBatis Generator] 的官方英文文档。中文文档已经看过了,没有找到相关的内容。在阅读英文文档中,我在Database Specific Information (使用注意事项)下面的 mysql使用注意事项 中似乎找到了相关的内容。其原内容如下:

If you are using version 8.x of Connector/J you may notice that the generator attempts to generate code for tables in the MySql information schemas (sys, information_schema, performance_schema, etc.) This is probably not what you want! To disable this behavior, add the property “nullCatalogMeansCurrent=true” to your JDBC URL.

For example:

  <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost/my_schema"
      userId="my_user" password="my_password">
    <property name="nullCatalogMeansCurrent" value=true" />
  </jdbcConnection>

上面的英文文档翻译过来就是:

如果您使用的是Connector / J的8.x版,您可能会注意到生成器尝试为MySql信息模式(sys,information_schema,performance_schema等)中的表生成代码。这可能不是您想要的! 要禁用此行为,请将属性“nullCatalogMeansCurrent = true”添加到JDBC

的确,我发现使用 8.0 版的驱动比使用 5.0 版时不仅 mapper.xml 文件中多生成了好多代码,而且还多生成了一个 xxxWithBLOBs 的 pojo 文件。虽然还是不太理解上面说的问题,但是我还是添加 nullCatalogMeansCurrent 属性。然后重新生成了相关的 mapper , pojo , dao 。打开之前出现问题的 mapper.xml 文件,和使用 5.0 版的驱动生成的代码一样,以 BaseResultMap 作为 id 的 resultMap 只有一个了。再次启动 Tomact,成功启动,没有任何问题,测试其他业务功能,也没有任何问题。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • mybatis的dtd约束文件及配置文件xml自动提示操作

    mybatis的dtd约束文件及配置文件xml自动提示操作

    这篇文章主要介绍了mybatis的dtd约束文件及配置文件xml自动提示操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • Springboot项目快速实现拦截器功能

    Springboot项目快速实现拦截器功能

    上一篇文章介绍了Springboot项目如何快速实现过滤器功能,本篇文章接着来盘一盘拦截器,仔细研究后会发现,其实拦截器和过滤器的功能非常类似,可以理解为面向切面编程的一种具体实现。感兴趣的小伙伴可以参考阅读
    2023-03-03
  • Java多线程CyclicBarrier的实现代码

    Java多线程CyclicBarrier的实现代码

    CyclicBarrier可以使一定数量的线程反复地在栅栏位置处汇集,本文通过实例代码介绍下Java多线程CyclicBarrier的相关知识,感兴趣的朋友一起看看吧
    2022-02-02
  • java JTree JCheckBox树复选框详解

    java JTree JCheckBox树复选框详解

    这篇文章主要为大家详细介绍了java JTree JCheckBox树复选框的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • 详解使用Spring Boot开发Web项目

    详解使用Spring Boot开发Web项目

    这篇文章主要介绍了详解使用Spring Boot开发Web项目,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-04-04
  • Springboot获取jar包中resources资源目录下的文件

    Springboot获取jar包中resources资源目录下的文件

    今天在项目中遇到一个业务场景,需要用到resources资源目录下的文件,本文主要介绍了Springboot获取jar包中resources资源目录下的文件,感兴趣的可以了解一下
    2023-12-12
  • Java排序算法之桶排序算法解析

    Java排序算法之桶排序算法解析

    这篇文章主要介绍了Java排序算法之桶排序算法解析,桶排序 (Bucket sort)或所谓的箱排序,是一个排序算法,工作原理是将数组分到有限数量的桶子里,每个桶子再个别排序,有可能再使用别的排序算法或是以递归方式继续使用桶排序进行排序,需要的朋友可以参考下
    2023-10-10
  • SpringBoot中间件封装限流器的方案详解

    SpringBoot中间件封装限流器的方案详解

    这篇文章主要介绍了SpringBoot中间件封装限流器,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • MyBatis-Plus实现对查询结果进行分页的基本步骤

    MyBatis-Plus实现对查询结果进行分页的基本步骤

    MyBatis-Plus 是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生,MyBatis-Plus 支持多种数据库的分页查询,其分页功能是通过 Page 类实现的,本文介绍了使用 MyBatis-Plus 实现分页查询的基本步骤,需要的朋友可以参考下
    2024-08-08
  • Java关于JDK1.8新特性的Stream流

    Java关于JDK1.8新特性的Stream流

    这篇文章主要介绍了版本薇JDK1.8 的Java中的Stream流,Stream流是一个来自数据源的元素队列并支持聚合操作,感兴趣的朋友可以参考下面文章内容
    2021-09-09

最新评论