如何获取 SQL 连接的默认模式?
Posted
技术标签:
【中文标题】如何获取 SQL 连接的默认模式?【英文标题】:How to get the default schema of a SQL connection? 【发布时间】:2013-11-27 09:30:21 【问题描述】:从 java 代码中 - 我已经连接到数据库 - 我需要找到连接的默认模式。
我有以下代码,它为我提供了该连接的所有模式的列表。
rs = transactionManager.getDataSource().getConnection().getMetaData().getSchemas();
while (rs.next())
log.debug("The schema is and the catalogue is ", rs.getString(1), rs.getString(2));
但是,我不想要所有模式的列表。我需要此连接的默认架构。
请帮忙。
注意 1:我在 Windows7(开发盒)和 Linux Redhat(生产盒)上使用 H2 和 DB2
注 2:我最后得出结论,使用 Java 中的 Connections 对象无法使用相同的代码找到 H2 和 DB2 的默认模式。我用配置文件解决了这个问题。但是,如果有人可以分享解决方案,我可以回去重构代码。
【问题讨论】:
没有返回“默认”(甚至是“当前”模式)的 JDBC API。我们需要知道您使用的是哪个 DBMS?甲骨文? Postgres? 在H2DB
上,您可以发出以下查询SELECT * FROM INFORMATION_SCHEMA.SESSION_STATE WHERE KEY='SCHEMA_SEARCH_PATH'
(请参阅:***.com/questions/10141739/…)。在 DB2 上VALUES CURRENT SCHEMA
@Alex 你应该把这个答案放在答案的部分,而不是放在 cmets 里。
@AngocA 我知道,我只是路过
您的 DB2 服务器在哪个平台 (OS) 上运行?
【参考方案1】:
请使用connection.getMetaData().getURL()
方法,它返回类似的字符串
jdbc:mysql://localhost:3306/?autoReconnect=true&useUnicode=true&characterEncoding=utf8
我们可以轻松解析它并获取架构名称。它适用于所有 JDBC 驱动程序。
【讨论】:
以上是关于如何获取 SQL 连接的默认模式?的主要内容,如果未能解决你的问题,请参考以下文章
如何从 SQL Server Express 获取连接字符串?