Mysql 8.0版本驱动getTables返回全部库的表的问题

  • MySQL Connector/J 8.0版本驱动向下兼容以前的5.5+版本MySQL,若是你使用的是5.5+版本MySQL,均可以升级成8.0版本驱动。
  • 若是你是使用的5.X版本驱动,须要将Driver Class换成: com.mysql.cj.jdbc.Driver

须要注意的是:
8.0版本驱动DataSource相关的参数有变化:html

好比8.0版本驱动将参数 nullCatalogMeansCurrent 的默认值由true改成了false,若是你使用DatabaseMetaData.getTables获取全部的表信息,8.0版本驱动将返回全部库的表。java

// 默认会返回全部库的表,而不只是datasource指定的库
databaseMetaData.getTables(null, null, null, new String[]{"TABLE"})

解决方案就是在链接池初始化时,将这个参数改成true,以HikariCP为例:mysql

Java Config:git

HikariConfig config = new HikariConfig();
...
config.addDataSourceProperty("nullCatalogMeansCurrent", true);

Spring Boot 配置:github

spring.datasource.hikari.data-source-properties.nullCatalogMeansCurrent=true

其余参数变化请参考[官方文档]spring


Diboot - 简单高效的轻代码开发框架sql

相关文章
相关标签/搜索