如何获取 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 获取连接字符串?

如何在 Laravel 中将连接结果作为对象数组获取?

如何在java中获取默认日期模式?

使用 oracle jdbc 连接时如何获取数据库模式名称?

SQL 在 Netezza 中获取某些数据库的默认模式?

如何获取 Sql Server 数据库中所有模式的列表