网站首页 > 技术文章 正文
前一个小结介绍了JDBC之ParameterMetaData参数元数据对象的常见方法及其使用,这里继续介绍JDBC中的DatabaseMetaData数据库元数据对象的常见方法及其使用。
DatabaseMetaData是一个位于java.sql包下的接口,它是对数据库信息的描述,通过Connection数据库链接对象,可以获取到DatabaseMetaData数据库元数据对象。例如可以获取到下面这些信息:
- 数据库链接地址。
 - 当前访问这个数据库的用户名。
 - 数据库产品名称,例如:是mysql数据库,还是oracle数据库等。
 - 获取数据库驱动名称。
 - 获取数据库驱动版本。
 - 获取数据表信息。
 - 获取表字段信息。
 - 获取表的主键信息。
 
1.1、获取DatabaseMetaData对象
要获取DatabaseMetaData对象,需要调用Connection数据库链接对象中的getMetaData()方法,这个方法返回的就是数据库元数据对象。
package com.gitcode.jdbc.chapter09;
import java.sql.*;
/**
 * @author ZhuYouBin
 * @version 1.0.0
 * @date 2024/6/17 16:55
 * @description DatabaseMetaData 对象
 */
public class DatabaseMetaDataDemo {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        // 1、加载类对象,并且注册Driver驱动对象
        Class.forName("com.mysql.cj.jdbc.Driver");
        // 2、获取数据库连接
        String url = "jdbc:mysql://127.0.0.1:3306/jdbc-study";
        String username = "root";
        String password = "root";
        Connection connection = DriverManager.getConnection(url, username, password);
        // 获取数据库元对象信息
        DatabaseMetaData metaData = connection.getMetaData();
        // 5、关闭连接
        connection.close();
    }
}1.2、getURL()方法
getURL()方法的作用:获取到当前数据库的链接地址url。
Connection connection = DriverManager.getConnection(url, username, password);
// 获取数据库元对象信息
DatabaseMetaData metaData = connection.getMetaData();
// 获取链接地址
String url1 = metaData.getURL();
System.out.println("数据库链接地址:" + url1);1.3、getDatabaseProductName()方法
getDatabaseProductName()方法的作用:获取当前数据库的产品名称,即:MySQL、Oracle等数据库。另外,还可以调用getDatabaseProductVersion()方法,获取当前数据库产品的版本号。例如:采用的是MySQL 8.x的版本,还是MySQL 5.x的版本。
Connection connection = DriverManager.getConnection(url, username, password);
// 获取数据库元对象信息
DatabaseMetaData metaData = connection.getMetaData();
// 获取数据库名称
String databaseProductName = metaData.getDatabaseProductName();
System.out.println("数据库名称:" + databaseProductName);
// 获取数据库版本号
String databaseProductVersion = metaData.getDatabaseProductVersion();
System.out.println("数据库版本号:" + databaseProductVersion);1.4、getDriverName()方法
getDriverName()方法的作用:获取当前数据库的驱动名称。另外,还可以调用getDriverVersion()方法,获取到驱动的版本号。
Connection connection = DriverManager.getConnection(url, username, password);
// 获取数据库元对象信息
DatabaseMetaData metaData = connection.getMetaData();
// 获取驱动名称
String driverName = metaData.getDriverName();
System.out.println("驱动名称:" + driverName);
// 获取驱动版本号
String driverVersion = metaData.getDriverVersion();
System.out.println("驱动版本号:" + driverVersion);1.5、getUserName()方法
getUserName()方法的作用:获取当前访问这个数据库的用户名称。
Connection connection = DriverManager.getConnection(url, username, password);
// 获取数据库元对象信息
DatabaseMetaData metaData = connection.getMetaData();
// 当前访问的数据库用户名
String userName = metaData.getUserName();
System.out.println("当前访问的数据库用户名:" + userName);1.6、getTables()方法
getTables()方法的作用:获取数据库中的数据表信息,可以获取指定的表,也可以获取所有表。getTables()方法有四个方法参数,分别是:
- catalog参数:指定数据库名称,设置null则获取所有数据库下的表信息。
 - schemaPattern参数:表空间匹配模式,MySQL没有表空间的概念,直接写null即可。
 - tableNamePattern参数:表名称匹配模,即:要获取的数据表名称。要获取所有数据表,则可以使用【%】百分号。
 - types[]参数:要获取的表类型,常见的有:TABLE数据表、VIEW视图。设置null,则表示返回所有。
 
Connection connection = DriverManager.getConnection(url, username, password);
// 获取数据库元对象信息
DatabaseMetaData metaData = connection.getMetaData();
// 获取数据表
ResultSet resultSet = metaData.getTables("jdbc-study", null, "t_user", null);
while (resultSet.next()) {
    String tableName = resultSet.getString("TABLE_NAME");
    System.out.println("数据表:" + tableName);
}1.7、getColumns()方法
getColumns()方法的作用:获取数据表中的列字段信息,getColumns()方法也有四个参数,分别是:
- catalog参数:指定数据库名称,设置null则获取所有数据库下的表信息。
 - schemaPattern参数:表空间匹配模式,MySQL没有表空间的概念,直接写null即可。
 - tableNamePattern参数:表名称匹配模,即:要获取的数据表名称。要获取所有数据表,则可以使用【%】百分号。
 - columnNamePattern参数:列名称匹配模式,设置null则获取表中所有列字段。
 
Connection connection = DriverManager.getConnection(url, username, password);
// 获取数据库元对象信息
DatabaseMetaData metaData = connection.getMetaData();
// 获取数据库表字段
ResultSet rs2 = metaData.getColumns("jdbc-study", null, "t_user", null);
while (rs2.next()) {
    String columnName = rs2.getString("COLUMN_NAME");
    System.out.print("数据库表字段:" + columnName + "\t");
}1.8、getPrimaryKeys()方法
getPrimaryKeys()方法的作用:获取数据表中的主键字段,可能是单主键(一个字段),也有可能是联合主键(多个字段)。
Connection connection = DriverManager.getConnection(url, username, password);
// 获取数据库元对象信息
DatabaseMetaData metaData = connection.getMetaData();
// 获取数据表主键
ResultSet rs3 = metaData.getPrimaryKeys("jdbc-study", null, "t_user");
while (rs3.next()) {
    String primaryKey = rs3.getString("COLUMN_NAME");
    System.out.println("数据表主键:" + primaryKey);
}以上代码最终执行结果,如下图所示:
1.9、源代码获取
源代码地址:
https://gitcode.com/qq_39826207/jdbc-study/tree/chapter-jdbc-09
今天就到这里,未完待续~~
- 上一篇: 中华财险面经分享(中华财险 待遇)
 - 下一篇: 【MySQL】七种约束超详解(mysql有哪几种约束)
 
猜你喜欢
- 2025-09-03 InnoDB 聚集索引和非聚集索引、覆盖索引、回表、索引下推简述
 - 2025-06-10 如何理解Mysql的索引及他们的原理?
 - 2025-06-10 性能测试——测试常见的指标(测试性能指标有哪些)
 - 2025-06-10 mysql中的分区表和合并表详解(一个常见知识点)
 - 2025-06-10 Oracle优化-建立索引(三)(oracle 索引优化)
 - 2025-06-10 MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
 - 2025-06-10 你写的 SQL 查询为什么总是慢?揭秘 MySQL 索引机制与联合索引
 - 2025-06-10 回表、覆盖索引(sqlserver覆盖索引)
 - 2025-06-10 数据库主从复制,读写分离,分库分表,分区详解
 - 2025-06-10 如何在在量化交易程序中高效使用sqlite
 
- 最近发表
 - 
- 聊一下 gRPC 的 C++ 异步编程_grpc 异步流模式
 - [原创首发]安全日志管理中心实战(3)——开源NIDS之suricata部署
 - 超详细手把手搭建在ubuntu系统的FFmpeg环境
 - Nginx运维之路(Docker多段构建新版本并增加第三方模
 - 92.1K小星星,一款开源免费的远程桌面,让你告别付费远程控制!
 - Go 人脸识别教程_piwigo人脸识别
 - 安卓手机安装Termux——搭建移动服务器
 - ubuntu 安装开发环境(c/c++ 15)_ubuntu安装c++编译器
 - Rust开发环境搭建指南:从安装到镜像配置的零坑实践
 - Windows系统安装VirtualBox构造本地Linux开发环境
 
 
- 标签列表
 - 
- cmd/c (90)
 - c++中::是什么意思 (84)
 - 标签用于 (71)
 - 主键只能有一个吗 (77)
 - c#console.writeline不显示 (95)
 - pythoncase语句 (88)
 - es6includes (74)
 - sqlset (76)
 - apt-getinstall-y (100)
 - node_modules怎么生成 (87)
 - chromepost (71)
 - flexdirection (73)
 - c++int转char (80)
 - mysqlany_value (79)
 - static函数和普通函数 (84)
 - el-date-picker开始日期早于结束日期 (76)
 - js判断是否是json字符串 (75)
 - c语言min函数头文件 (77)
 - asynccallback (87)
 - localstorage.removeitem (77)
 - vector线程安全吗 (73)
 - java (73)
 - js数组插入 (83)
 - mac安装java (72)
 - 无效的列索引 (74)
 
 
