JAVA基础 之 DatabaseMetaData

Java基础专栏上线啦~     传送门

概述:

    1.DatabaseMetaData:连接对应的数据库信息对象

    2.通过con.getMetaData();方法来获得

    3.不多说看例子

 

package com.cxy.jdbc;

import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;

/**
 * @author cxy
 */
public class DatabaseMetaDataTest
{
	public static void main(String[] args) throws Exception
	{
		Class.forName("com.mysql.jdbc.Driver");
		try
		(
			Connection con=DriverManager.getConnection("jdbc:mysql://localhost/dbtest", "root", "root");
		)
		{
			DatabaseMetaData dmd=con.getMetaData();
			System.out.println("当前数据库是:"+dmd.getDatabaseProductName());
			System.out.println("当前数据库版本:"+dmd.getDatabaseProductVersion());
			System.out.println("当前数据库驱动:"+dmd.getDriverVersion());
			System.out.println("当前数据库URL:"+dmd.getURL());
			System.out.println("当前数据库是否是只读模式?:"+dmd.isReadOnly());
			System.out.println("当前数据库是否支持批量更新?:"+dmd.supportsBatchUpdates());
			System.out.println("当前数据库是否支持结果集的双向移动(数据库数据变动不在ResultSet体现)?:"+dmd.supportsResultSetType(ResultSet.TYPE_SCROLL_INSENSITIVE));
			System.out.println("当前数据库是否支持结果集的双向移动(数据库数据变动会影响到ResultSet的内容)?:"+dmd.supportsResultSetType(ResultSet.TYPE_SCROLL_SENSITIVE));
			System.out.println("========================================");
			
			ResultSet rs=dmd.getTables(null, null, "%", null);
			System.out.println("表名"+","+"表类型");
			while(rs.next())
			{
				System.out.println(rs.getString("TABLE_NAME")+","+rs.getString("TABLE_TYPE"));
			}
			System.out.println("========================================");
			
			rs=dmd.getPrimaryKeys(null, null, "t_student");
			while(rs.next())
			{
				System.out.println(rs.getString(3)+"表的主键是:"+rs.getString(4));
			}
			System.out.println("========================================");
			
			rs=dmd.getColumns(null, null, "t_student","%");
			System.out.println("t_student表包含的字段:");
			while(rs.next())
			{
				System.out.println(rs.getString(4)+" "+rs.getString(6)+"("+rs.getString(7)+");");
			}
			System.out.println("========================================");
			
		}catch(SQLException e)
		{
			System.out.println("数据库操作出现异常");
		}
	}

}

相关连接:

《Java基础 之 RowSet》

《Java基础 之 ResultSet》

《Java基础 之 ResultSetMetaData》

《Java基础 之 JDBC》

 

声明:

1.原创文章,转载请标明并加本文连接。

2.文章反映个人愚见,如有异议欢迎讨论指正

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java DatabaseMetaData接口中的getCatalogs()方法用于获取数据库中所有可用的目录名称,返回一个ResultSet对象,其中包含一个包含目录名称的列。 以下是一个示例代码,演示如何使用getCatalogs()方法获取数据库中的目录名称: ```java import java.sql.*; public class Example { public static void main(String[] args) throws SQLException { // Establishing a connection to the database Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydatabase", "username", "password"); // Retrieving the database metadata object DatabaseMetaData metaData = conn.getMetaData(); // Retrieving all the available catalogs in the database ResultSet catalogs = metaData.getCatalogs(); // Iterating through the ResultSet to print all the catalog names while(catalogs.next()) { String catalogName = catalogs.getString("TABLE_CAT"); System.out.println("Catalog Name: " + catalogName); } // Closing the ResultSet and database connection catalogs.close(); conn.close(); } } ``` 在上面的示例中,我们首先建立了一个与数据库的连接,然后使用getConnection()方法获取一个Connection对象。接下来,我们使用Connection对象的getMetaData()方法获取一个DatabaseMetaData对象。最后,我们使用DatabaseMetaData对象的getCatalogs()方法检索所有可用的目录,并使用ResultSet对象的next()和getString()方法迭代ResultSet以打印每个目录的名称。 请注意,在使用完ResultSet对象后,我们需要通过调用close()方法关闭它,以及关闭数据库连接。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值