34

我需要处理返回三个数据库(Oracle、sybase、MS-Server)的存储过程/函数的结果集。过程/功能通常是相同的,但在 Oracle 中的调用略有不同。

statement.registerOutParameter(1, oracle.jdbc.OracleTypes.CURSOR);
...
statement.execute(); 
ResultSet rs = (ResultSet)statement.getObject(1);

JDBC 没有提供通用的方法来处理这个问题,所以我需要在我的代码中区分不同类型的 DB。我得到了连接,但不知道确定数据库是否是 oracle 的最佳方法。我可以使用驱动程序名称,但宁愿找到一种更简洁的方法。

4

2 回答 2

55

我怀疑你会想要使用 DatabaseMetaData 类。很可能DatabaseMetaData.getDatabaseProductName就足够了,但如果您的代码依赖于您正在使用的特定数据库的特定版本,您可能还想使用 getDatabaseProductVersion 方法。

于 2008-10-31T17:01:47.510 回答
3

You can use org.apache.ddlutils, class Platformutils:

databaseName = new PlatformUtils().determineDatabaseType(dataSource)
于 2012-01-30T13:42:41.567 回答