博客
关于我
获取当前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/

你可能感兴趣的文章
memset初始化高维数组为-1/0
查看>>
Metasploit CGI网关接口渗透测试实战
查看>>
Metasploit Web服务器渗透测试实战
查看>>
Moment.js常见用法总结
查看>>
MongoDB出现Error parsing command line: unrecognised option ‘--fork‘ 的解决方法
查看>>
mxGraph改变图形大小重置overlay位置
查看>>
MongoDB学习笔记(8)--索引及优化索引
查看>>
MQTT工作笔记0009---订阅主题和订阅确认
查看>>
ms sql server 2008 sp2更新异常
查看>>
MS UC 2013-0-Prepare Tool
查看>>
msbuild发布web应用程序
查看>>
MSB与LSB
查看>>
MSCRM调用外部JS文件
查看>>
MSCRM调用外部JS文件
查看>>
MSEdgeDriver (Chromium) 不适用于版本 >= 79.0.313 (Canary)
查看>>
MsEdgeTTS开源项目使用教程
查看>>
msf
查看>>
MSSQL数据库查询优化(一)
查看>>
MSSQL日期格式转换函数(使用CONVERT)
查看>>
MSTP多生成树协议(第二课)
查看>>