bug:
mybatis-generator-maven-plugin 插件在自动生成代码时配置不当,会生成别的数据库同名数据库表相关内容。
原因:
使用 mysql-connector-java 8.x 版本,generator 会使用MySql中的schema(直接使用表schema)信息来找表,而不是catlog(db.tableSchema)来生成代码,若要避免这种操作,请在 JDBC URL 中加入属性“nullCatalogMeansCurrent=true”。
原来的mybaits generator xml中的jdbc配置内容:
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/DBName?useUnicode=true&characterEncodeing=utf-8&serverTimezone=GMT&2B8&useSSL=false&allowPublicKeyRetrieval=true"
userId="userName"
password="password"
>
</jdbcConnection>
解决方案
在mysql Url中加入 nullCatalogMeansCurrent=true&
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/数据库名?nullCatalogMeansCurrent=true&useUnicode=true&characterEncodeing=utf-8&serverTimezone=GMT&2B8&useSSL=false&allowPublicKeyRetrieval=true"
userId="数据库用户名"
password="数据库密码"
>
<!--<properties name="nullCatalogMeansCurrent" value="true" />-->
</jdbcConnection>
或者在配置文件加入如上的配置项;
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/DBName?useUnicode=true&characterEncodeing=utf-8&serverTimezone=GMT&2B8&useSSL=false&allowPublicKeyRetrieval=true"
userId="userName"
password="password"
>
<properties name="nullCatalogMeansCurrent" value="true" />
</jdbcConnection>
呜呜呜~,刚开始还以为是缓存的问题就把orm换成了springDataJpa今天写个小项目用到了想着解决一下,查看了官网才发现有这么个秘密