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,如需转载请自行联系原作者
相关文章
|
7月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
502 158
|
8月前
|
安全 Java 编译器
new出来的对象,不一定在堆上?聊聊Java虚拟机的优化技术:逃逸分析
逃逸分析是一种静态程序分析技术,用于判断对象的可见性与生命周期。它帮助即时编译器优化内存使用、降低同步开销。根据对象是否逃逸出方法或线程,分析结果分为未逃逸、方法逃逸和线程逃逸三种。基于分析结果,编译器可进行同步锁消除、标量替换和栈上分配等优化,从而提升程序性能。尽管逃逸分析计算复杂度较高,但其在热点代码中的应用为Java虚拟机带来了显著的优化效果。
261 4
|
7月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
528 156
|
7月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
633 161
|
监控 Java Unix
6个Java 工具,轻松分析定位 JVM 问题 !
本文介绍了如何使用 JDK 自带工具查看和分析 JVM 的运行情况。通过编写一段测试代码(启动 10 个死循环线程,分配大量内存),结合常用工具如 `jps`、`jinfo`、`jstat`、`jstack`、`jvisualvm` 和 `jcmd` 等,详细展示了 JVM 参数配置、内存使用、线程状态及 GC 情况的监控方法。同时指出了一些常见问题,例如参数设置错误导致的内存异常,并通过实例说明了如何排查和解决。最后附上了官方文档链接,方便进一步学习。
2864 4
|
6月前
|
存储 Java Go
【Java】(3)8种基本数据类型的分析、数据类型转换规则、转义字符的列举
牢记类型转换规则在脑海中将编译和运行两个阶段分开,这是两个不同的阶段,不要弄混!
333 2
|
6月前
|
Java Go 开发工具
【Java】(9)抽象类、接口、内部的运用与作用分析,枚举类型的使用
抽象类必须使用abstract修饰符来修饰,抽象方法也必须使用abstract修饰符来修饰,抽象方法不能有方法体。抽象类不能被实例化,无法使用new关键字来调用抽象类的构造器创建抽象类的实例。抽象类可以包含成员变量、方法(普通方法和抽象方法都可以)、构造器、初始化块、内部类(接 口、枚举)5种成分。抽象类的构造器不能用于创建实例,主要是用于被其子类调用。抽象类中不一定包含抽象方法,但是有抽象方法的类必定是抽象类abstract static不能同时修饰一个方法。
302 1
|
7月前
|
人工智能 数据挖掘 数据库
通义灵码产品演示: 数据库设计与数据分析
本演示展示如何使用通义灵码进行数据库设计与数据分析。通过SQLite构建电商订单表,利用AI生成表结构、插入样本数据,并完成多维度数据分析及可视化图表展示,体现AI在数据库操作中的高效能力。
628 7
|
7月前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案

热门文章

最新文章

下一篇
开通oss服务