《JDBC》第09节:JDBC之DatabaseMetaData数据库元数据对象

前一个小结介绍了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

今天就到这里,未完待续~~

相关文章

Java 反射 和 Java new 的效率有什么区别,亲测相差100倍

在我们的日常使用中,Java new是用的最多的,但是有些框架往往会使用Java反射来实现灵活性,那么它们之间的效率有什么区别呢?你有没有想过,什么时候应该该用new来创建对象,什么时候该使用反射呢?...

JAVA进阶知识学习-day01 Object类&Date类&System类

一、Object类1.1 java.lang.Object类是Java语言中的根类,即所有类的父类。它中描述的所有方法子类都可以使用。在对象实例化的时候,最终找的父类就是Object。 如果一个类没有...

一文搞懂JAVA 中的引用

介绍JAVA 中有 4 种类型的引用:-强引用-软引用-弱引用-虚引用这些引用仅在垃圾收集器管理它们的方式上有所不同。如果您从未听说过它们,则意味着您只使用过强的。了解其中的区别会对您有所帮助,尤其是...

java反射的核心原理和使用

一、Java 反射的核心概念反射的本质是通过 Class 对象与 JVM 的交互,获取和操作类的字节码数据(如方法、字段等)。以下是反射的核心概念:1.Class 对象:每个 Java 类在 JVM...

Java 反射

Java的反射功能,可以帮我们在程序“运行期间““自由的”创建对象,那为什么强调运行期间呢?那是因为我们创建对象一般是在编译期间就创建好了,例如:我们在代码中new了一个对象,这个时候java源码文件...

java面向对象特性,抽象,封装,继承,多态

1. 抽象(Abstraction)定义: 抽象是指将复杂的事物进行简化,通过隐藏实现细节,只暴露接口或核心功能。它是面向对象编程中的一种机制,允许我们定义“抽象类”和“接口”,从而强制子类实现某些方...