Java 如何获取SQL连接的默认模式?

Java 如何获取SQL连接的默认模式?,java,sql,db2,h2,Java,Sql,Db2,H2,在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)); } 下面的代码给出了该连接的

在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));
}
下面的代码给出了该连接的所有模式的列表

rs  = transactionManager.getDataSource().getConnection().getMetaData().getSchemas();
while (rs.next()) {
    log.debug("The schema is {} and the catalogue is {} ", rs.getString(1), rs.getString(2));
}
但是,我不想要所有模式的列表。我需要此连接的默认架构

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的默认模式(使用相同的代码)是不可能的。我修复了配置文件的问题。但是,如果有人可以共享一个解决方案,我可以回去重构代码

请使用
connection.getMetaData().getURL()
方法,该方法返回字符串

jdbc:mysql://localhost:3306/?autoReconnect=true&useUnicode=true&characterEncoding=utf8

我们可以轻松地解析它并获得模式名称。它适用于所有JDBC驱动程序。

没有返回“默认”(甚至“当前”模式)的JDBC API。我们需要知道您使用的是哪种DBMS?神谕Postgres?在
H2DB
上,您可以发出以下查询
SELECT*FROM INFORMATION\u SCHEMA.SESSION\u STATE,其中KEY='SCHEMA\u SEARCH\u PATH'
(请参阅:)。在DB2
VALUES CURRENT SCHEMA
@Alex上,您应该把这个答案放在答案部分,而不是放在注释中。@AngocA我知道,我只是路过您的DB2服务器运行在什么平台(OS)上?