java 获取spring 数据源_关于Java:如何从Spring JdbcTemplate获取数据库供应商名称

这篇博客讨论了如何在Java中使用Spring JdbcTemplate无须通过Connection接口获取数据库供应商名称。通过调用`getDataSource().getConnection().getMetaData().getDatabaseProductName()`可以直接获取,但建议使用`ConnectionCallback`以避免手动管理连接。此外,`JdbcUtils`类提供了`extractDatabaseMetaData`和`commonDatabaseName`方法,可以帮助标准化和简化这个过程。
摘要由CSDN通过智能技术生成

我正在使用spring Jdbc,如何不通过Connection接口从jdbc模板检索数据库供应商名称。 Spring是否提供了一个API,可以提供一个持有数据库名称的枚举,以便我可以将代码与硬编码字符串值解耦

您可以在DatabaseMetaData文档中找到所需的信息。

String vendor = jdbcTemplate.getDataSource().getConnection().getMetaData().getDatabaseProductName();

更新!

根据M. Deinum的建议,您可以使用ConnectionCallback,因此您无需关闭连接或进行连接。

例如:

private String getProduct() {

return this.jdbcTemplate.execute(new ConnectionCallback() {

@Override

public String doInConnection(Connection connection) throws SQLException,

DataAccessException {

return connection.getMetaData().getDatabaseProductName();

}

});

}

实际上,这很危险,因为您正在打开一个非托管连接。相反,您应该使用ConnectionCallback或再次关闭连接。

好吧,这是一个如何找到他想要的信息的示例。当然必须对连接进行良好的管理,但这不是这里的问题。问题是在哪里可以找到此信息,我认为您无需使用Connecti

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值