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

作者:Dmego的博客 时间:2024-01-16 16:48:19 

前言

今天在使用 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,成功启动,没有任何问题,测试其他业务功能,也没有任何问题。

来源:https://dmego.me/2018/10/10/mysql8-mybatis-geneator.html

标签:Mybatis,逆向工程,Mysql8.0
0
投稿

猜你喜欢

  • Python编程中用close()方法关闭文件的教程

    2023-02-10 22:10:06
  • IP地址正则表达式匹配方法

    2023-06-11 18:58:03
  • python编程开发之textwrap文本样式处理技巧

    2022-03-20 18:48:26
  • Python入门之后再看点什么好?

    2023-07-17 07:04:29
  • Centos7.3下mysql5.7.18安装并修改初始密码的方法

    2024-01-20 00:02:11
  • .NET 6中为record类型自定义Equals方法

    2023-07-15 21:29:29
  • JS与jQ读取xml文件的方法

    2024-04-19 10:13:22
  • JS和函数式语言的三特性

    2024-04-17 10:10:57
  • mysql8.0.11 winx64安装配置方法图文教程(win10)

    2024-01-23 07:58:58
  • python利用xlsxwriter模块 操作 Excel

    2023-02-11 00:43:02
  • Python+Pygame实战之24点游戏的实现

    2023-11-07 21:14:12
  • js constructor的实际作用分析

    2024-02-25 01:41:31
  • Python实现压缩文件夹与解压缩zip文件的方法

    2023-07-31 20:43:09
  • 什么是SVG(可升级矢量图形)

    2008-05-06 12:37:00
  • pycharm 无法加载文件activate.ps1的原因分析及解决方法

    2022-07-11 01:00:49
  • asp函数遍历文件夹代码

    2010-06-21 10:38:00
  • python实现提取百度搜索结果的方法

    2021-05-13 20:27:21
  • 利用python实现平稳时间序列的建模方式

    2022-08-31 03:35:30
  • 详解Mysql中的JSON系列操作函数

    2024-01-20 02:08:08
  • Pygame改编飞机大战制作兔子接月饼游戏

    2023-04-09 02:57:22
  • asp之家 网络编程 m.aspxhome.com