博客
关于我
获取当前jdbc连接的数据库名称
阅读量:677 次
发布时间:2019-03-16

本文共 646 字,大约阅读时间需要 2 分钟。

今天在工作中遇到一个业务:“在jdbc已经与数据库建立连接的情况下,需要在业务代码中获取到不同类型数据库的库名。”像大多数人一样,我首先想到的是通过jdbc连接的url来获取数据库名,例如mysql的jdbc连接url

jdbc:mysql://localhost:3306/test

oracle的jdbc连接url

jdbc:oracle:thin:@127.0.0.1:1521:orcl

显然,通过jdbc连接url是可以获取到数据库名的,但是通过这种方式获取库名首先需要通过不同的方式截取字符串,其次如果换做其他类型的如MongoDB、HBase等数据库,还要通过各自的截取方式来获取,因此这种方式很麻烦。于是乎,通过百度,搜到的大部分都是通过“show databases”查询出所有的数据库名,并不能解决以上业务。最终,总算找到了一个简单的方法,使用jdbc通过以下sql直接进行查询,目前只找到了获取mysql和oracle数据库名的方式

1.MySQL获取当前连接数据库名称

select database();

2.Oracle获取当前连接数据库名称

select name from v$database;

3.SQLServer获取当前连接数据库名称

Select Name From Master..SysDataBases Where DbId=(Select Dbid From Master..SysProcesses Where Spid = @@spid)

转载地址:http://zlmqz.baihongyu.com/

你可能感兴趣的文章
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>
MySQL DBA 进阶知识详解
查看>>
Mura CMS processAsyncObject SQL注入漏洞复现(CVE-2024-32640)
查看>>
Mysql DBA 高级运维学习之路-DQL语句之select知识讲解
查看>>
mysql deadlock found when trying to get lock暴力解决
查看>>
MuseTalk如何生成高质量视频(使用技巧)
查看>>