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,如需转载请自行联系原作者
相关文章
|
9月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
543 158
|
8月前
|
SQL Java 数据库连接
除了JDBC,还有哪些常见的数据库访问技术?
除了JDBC,还有哪些常见的数据库访问技术?
674 2
|
9月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
591 156
|
9月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
697 161
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
9月前
|
人工智能 数据挖掘 数据库
通义灵码产品演示: 数据库设计与数据分析
本演示展示如何使用通义灵码进行数据库设计与数据分析。通过SQLite构建电商订单表,利用AI生成表结构、插入样本数据,并完成多维度数据分析及可视化图表展示,体现AI在数据库操作中的高效能力。
749 8
|
NoSQL Java API
在Java环境下如何进行Redis数据库的操作
总的来说,使用Jedis在Java环境下进行Redis数据库的操作,是一种简单而高效的方法。只需要几行代码,就可以实现复杂的数据操作。同时,Jedis的API设计得非常直观,即使是初学者,也可以快速上手。
472 94
|
存储 关系型数据库 MySQL
大数据新视界 --面向数据分析师的大数据大厂之 MySQL 基础秘籍:轻松创建数据库与表,踏入大数据殿堂
本文详细介绍了在 MySQL 中创建数据库和表的方法。包括安装 MySQL、用命令行和图形化工具创建数据库、选择数据库、创建表(含数据类型介绍与选择建议、案例分析、最佳实践与注意事项)以及查看数据库和表的内容。文章专业、严谨且具可操作性,对数据管理有实际帮助。
大数据新视界 --面向数据分析师的大数据大厂之 MySQL 基础秘籍:轻松创建数据库与表,踏入大数据殿堂
|
Java 关系型数据库 MySQL
Java汽车租赁系统源码(含数据库脚本)
Java汽车租赁系统源码(含数据库脚本)
589 4