功能:
- 可获得数据库相关信息
说明:
- Java使用DatabaseMetaData来获取数据库相关信息
- 本文为了代码结构清晰 采用的是try-with-resource结构,请在java7下使用(或者自己改成传统模式)
- 具体使用请看例子
部分API:
返回类型 | 方法名称 | 说明 |
---|---|---|
String | getDatabaseProductName() | 获得数据库产品的名称 |
String | getDatabaseProductVersion() | 获得数据库产品的版本 |
String | getDriverVersion() | 获得JDBC驱动的版本号 |
String | getURL() | 获得当前数据连接的URL |
boolean | isReadOnly() | 当前数据连接的数据库是否是只读模式 |
boolean | supportsBatchUpdates() | 数据库是否支持批量操作 |
boolean | supportsResultSetType(int type) | 数据库是否支持给定结果集类型 |
ResultSet | getTables(String catalog, String schemaPattern, String tableNamePattern, String[] types) | 简单的讲就是获得数据表的相关信息 |
ResultSet | getPrimaryKeys(String catalog, String schema, String table) | 获得某表的主键 |
ResultSet | getColumns(String catalog, String schemaPattern, String tableNamePattern, String columnNamePattern) | 获得某表字段信息 |
程序演示: 放大
- 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 @ www.cxyapi.com
- */
- 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("数据库操作出现异常");
- }
- }
- }
转载于:https://blog.51cto.com/congwa/1163841