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

你可能感兴趣的文章
netty代理
查看>>
Netty入门使用
查看>>
netty入门,入门代码执行流程,netty主要组件的理解
查看>>
Netty原理分析及实战(一)-同步阻塞模型(BIO)
查看>>
Netty原理分析及实战(三)-高可用服务端搭建
查看>>
Netty原理分析及实战(二)-同步非阻塞模型(NIO)
查看>>
Netty原理分析及实战(四)-客户端与服务端双向通信
查看>>
Netty发送JSON格式字符串数据
查看>>
Netty和Tomcat的区别已经性能对比
查看>>
Netty在IDEA中搭建HelloWorld服务端并对Netty执行流程与重要组件进行介绍
查看>>
Netty基础—1.网络编程基础一
查看>>
Netty基础—1.网络编程基础二
查看>>
Netty基础—2.网络编程基础三
查看>>
Netty基础—2.网络编程基础四
查看>>
Netty基础—3.基础网络协议一
查看>>
Netty基础—3.基础网络协议二
查看>>
Netty基础—4.NIO的使用简介一
查看>>
Netty基础—4.NIO的使用简介二
查看>>
Netty基础—5.Netty的使用简介
查看>>
Netty基础—6.Netty实现RPC服务一
查看>>