博客
关于我
获取当前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问题记录
查看>>
MySQL集群解决方案(1):MySQL数据库的集群方案
查看>>
MySQL集群解决方案(4):负载均衡
查看>>
MySQL集群解决方案(5):PXC集群
查看>>
MySQL面试宝典
查看>>
WAP短信:融合传统短信和互联网的新型通信方式
查看>>
mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
查看>>
Mysql面试题精选
查看>>
MySQL面试题集锦
查看>>
mysql面试题,存储引擎InnoDB和MyISAM
查看>>
mysql面试题:为什么MySQL单表不能超过2000W条数据?
查看>>
mysql面试题:创建索引时会不会锁表?
查看>>
mysql面试题:高度为3的B+树可以存放多少数据?
查看>>
mysql颠覆实战笔记(八)--mysql的自定义异常处理怎么破
查看>>
mysql驱动、durid、mybatis之间的关系
查看>>
mysql驱动支持中文_mysql 驱动包-Go语言中文社区
查看>>
MySQL高可用之——keepalived+互为主从
查看>>
MySQL高可用切换_(5.9)mysql高可用系列——正常主从切换测试
查看>>
MySQL高可用解决方案
查看>>
MySQL高可用解决方案详解
查看>>