Java基础系列15:JDBC中使用元数据分析数据库

简介:

(1)DatabaseMetaData:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
package  javase.jdbc;
 
import  java.sql.Connection;
import  java.sql.DatabaseMetaData;
import  java.sql.ResultSet;
import  java.sql.SQLException;
 
public  class  DatabaseMetaDataDemo {
 
     public  static  void  main(String[] args) {
         Connection connection = JDBCConnection.getConnection();
 
         try  {
             DatabaseMetaData dMetaData = connection.getMetaData();  // 实例化元数据
 
             System.out.println( "数据库名:"  + dMetaData.getDatabaseProductName());
             System.out.println( "数据库版本: "
                     + dMetaData.getDatabaseProductVersion());
 
             ResultSet resultSet = dMetaData.getPrimaryKeys( null null "users" );
             while  (resultSet.next()) {
                 System.out.println( "表类别:"  + resultSet.getString( 1 ));
                 System.out.println( "表模式:"  + resultSet.getString( 2 ));
                 System.out.println( "表名称:"  + resultSet.getString( 3 ));
                 System.out.println( "列名称:"  + resultSet.getString( 4 ));
                 System.out.println( "主键:"  + resultSet.getString( 5 ));
                 System.out.println( "主键名称:"  + resultSet.getString( 6 ));
             }
 
         catch  (SQLException e) {
             e.printStackTrace();
         }
 
     }
 
}

输出:

1
2
3
4
5
6
7
8
数据库名:MySQL
数据库版本: 5.5.19
表类别:jdbcdemo
表模式:null
表名称:users
列名称:id
主键:1
主键名称:PRIMARY

(2)ResultSetMetaData:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
package  javase.jdbc;
 
import  java.sql.Connection;
import  java.sql.PreparedStatement;
import  java.sql.ResultSetMetaData;
import  java.sql.SQLException;
 
public  class  ResultSetMetaDataDemo {
 
     public  static  void  main(String[] args) {
         String sql =  "SELECT id,username,password,classId FROM users" ;
         Connection connection = JDBCConnection.getConnection();
 
         try  {
             PreparedStatement pStatement = connection.prepareStatement(sql);
             ResultSetMetaData rSetMetaData = pStatement.getMetaData();
 
             System.out.println( "返回数据有"  + rSetMetaData.getColumnCount() +  "个字段" );
             if  (rSetMetaData.isAutoIncrement( 1 ))
                 System.out.println(rSetMetaData.getColumnName( 1 ) +  "字段是自增的" );
         catch  (SQLException e) {
             e.printStackTrace();
         }
 
     }
 
}

输出:

1
2
返回数据有4个字段
id字段是自增的



本文转自 pangfc 51CTO博客,原文链接:http://blog.51cto.com/983836259/1767351,如需转载请自行联系原作者
相关文章
|
3月前
|
SQL Java 数据库连接
除了JDBC,还有哪些常见的数据库访问技术?
除了JDBC,还有哪些常见的数据库访问技术?
332 2
|
4月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
182 3
|
5月前
|
安全 Java 编译器
new出来的对象,不一定在堆上?聊聊Java虚拟机的优化技术:逃逸分析
逃逸分析是一种静态程序分析技术,用于判断对象的可见性与生命周期。它帮助即时编译器优化内存使用、降低同步开销。根据对象是否逃逸出方法或线程,分析结果分为未逃逸、方法逃逸和线程逃逸三种。基于分析结果,编译器可进行同步锁消除、标量替换和栈上分配等优化,从而提升程序性能。尽管逃逸分析计算复杂度较高,但其在热点代码中的应用为Java虚拟机带来了显著的优化效果。
177 4
|
8月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
3月前
|
存储 Java Go
【Java】(3)8种基本数据类型的分析、数据类型转换规则、转义字符的列举
牢记类型转换规则在脑海中将编译和运行两个阶段分开,这是两个不同的阶段,不要弄混!
237 2
|
3月前
|
Java Go 开发工具
【Java】(9)抽象类、接口、内部的运用与作用分析,枚举类型的使用
抽象类必须使用abstract修饰符来修饰,抽象方法也必须使用abstract修饰符来修饰,抽象方法不能有方法体。抽象类不能被实例化,无法使用new关键字来调用抽象类的构造器创建抽象类的实例。抽象类可以包含成员变量、方法(普通方法和抽象方法都可以)、构造器、初始化块、内部类(接 口、枚举)5种成分。抽象类的构造器不能用于创建实例,主要是用于被其子类调用。抽象类中不一定包含抽象方法,但是有抽象方法的类必定是抽象类abstract static不能同时修饰一个方法。
242 0
|
4月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
264 6
|
4月前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
|
4月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
182 1