麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發(fā) > Java > 正文

詳解Mybatis逆向工程中使用Mysql8.0版本驅(qū)動遇到的問題

2024-07-14 08:42:29
字體:
供稿:網(wǎng)友

前言

今天在使用 8.0.12 版的 mysql 驅(qū)動時遇到了各種各樣的坑,在使用 JDBC 連接上遇到的問題可以參考我的上一篇。我在使用 mybatis 逆向工程生成各種 mapper , pojo , dao 時,遇到了一個困惑我好幾個小時的錯誤,這個錯誤是

Result Maps collection already contains value for BaseResultMap

產(chǎn)生這個錯誤可能有各種原因。但是這里我只說我的原因及解決過程。

初步探索

我在網(wǎng)上查閱了大量的博客文章,對于產(chǎn)生這類錯誤的原因最多的是:生成了多次 mapper , dao 以及 pojo 文件。也就是多次運行了生成這些文件的方法。造成 XXXmapper.xml 中出現(xiàn)了重復的 resultmap 。但是我這里把這些文件刪除后,再重新生成還是會報這個錯。所以肯定不是多次生成的問題。

于是我打開了出現(xiàn)問題的那個 Mapper.xml 文件,搜索 BaseResultMap 發(fā)現(xiàn)其作為 resultMap 的 id 居然出現(xiàn)了三次,還有很多其他的 sql 標簽的 id 也有很多重復的。我將這些重復的都刪除,再次運行,成功了,沒有出現(xiàn)錯誤。而且利用這些生成的 mapper 做后面的功能也沒有任何問題。這就非常奇怪,為什么會多生成這些代碼呢,我繼續(xù)在網(wǎng)上找相關(guān)的文章。

深入探索

好不容易找到一篇博客中提到 :升級到 mysql 8.0 驅(qū)動后的使用 mybatis 逆向工程生成的文件或不一樣,具體的怎么不一樣也沒有說。看到這里,我猜會不會是驅(qū)動版本造成的,于是我將 pom.xml 里的 mysql 驅(qū)動版本調(diào)整到了 5.1.10。刪干凈文件,再次生成后,發(fā)現(xiàn)之前出錯的那個 mapper.xml 里的 以 BaseResultMap 作為 id 的 resultMap 只有一個了,其他的 resultMap 中 id 也是唯一的。為了檢驗這次生成的到底有沒有用。我啟動 Tomact 運行程序。發(fā)現(xiàn)正常啟動,后續(xù)的功能也沒有問題。

最終解決

但是如果使用 5.0 版本的驅(qū)動連接 mysql 8.0 在項目中可能會遇到難以預料的問題,所以我并沒有就此將驅(qū)動版本改變。我繼續(xù)在網(wǎng)上通過換各種關(guān)鍵詞來搜尋解決方案。幾個小時過去了,還是沒有任何結(jié)果。最后被迫去看了 [MyBatis Generator] 的官方英文文檔。中文文檔已經(jīng)看過了,沒有找到相關(guān)的內(nèi)容。在閱讀英文文檔中,我在Database Specific Information (使用注意事項)下面的 mysql使用注意事項 中似乎找到了相關(guān)的內(nèi)容。其原內(nèi)容如下:

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

的確,我發(fā)現(xiàn)使用 8.0 版的驅(qū)動比使用 5.0 版時不僅 mapper.xml 文件中多生成了好多代碼,而且還多生成了一個 xxxWithBLOBs 的 pojo 文件。雖然還是不太理解上面說的問題,但是我還是添加 nullCatalogMeansCurrent 屬性。然后重新生成了相關(guān)的 mapper , pojo , dao 。打開之前出現(xiàn)問題的 mapper.xml 文件,和使用 5.0 版的驅(qū)動生成的代碼一樣,以 BaseResultMap 作為 id 的 resultMap 只有一個了。再次啟動 Tomact,成功啟動,沒有任何問題,測試其他業(yè)務(wù)功能,也沒有任何問題。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識閱讀請移步到JAVA教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产女厕一区二区三区在线视 | bt 自拍 另类 综合 欧美 | chengrenyingshi| 午夜视频在线看 | www.guochan| 成人午夜免费看 | 性欧美一区二区 | 黄视频在线网站 | 免费毛片在线 | 国产视频第一区 | 综合激情网 | 黄色片视频观看 | 欧美成人一区免费视频 | 色中色在线播放 | 亚洲精品动漫在线观看 | 亚洲成人激情av | 一本一本久久a久久精品综合小说 | 免费一区二区三区 | 欧美性生交大片 | 国产亚洲精品久久久久久久软件 | 毛片视频免费观看 | japanesexxxx24videofree| 黄网站免费入口 | 亚洲第一成av人网站懂色 | 毛毛片在线看 | 日本a v免费观看 | 成人18免费观看 | 国产精品亚洲精品日韩已方 | 新久草视频 | 激情大乳女做爰办公室韩国 | 中文在线观看免费视频 | 91精品国产乱码久 | 视频一区二区三区在线 | 免费视频www在线观看 | 成年性羞羞视频免费观看 | 国产精品久久久久久久av三级 | 久久精品一区二区三区不卡牛牛 | 欧美成年视频 | 国产亚洲精品久久久久久久 | 久久经典视频 | 黄色免费在线电影 |