`

ResultSetMetaData使用实例

 
阅读更多

本例中使用ORACLE数据库,表CLASS结构如下:

例子代码如下:

  1. import java.sql.Connection;
  2. import java.sql.DriverManager;
  3. import java.sql.PreparedStatement;
  4. import java.sql.ResultSet;
  5. import java.sql.ResultSetMetaData;
  6. import java.sql.SQLException;
  7. class TestDemo {
  8.     public static Connection getConnection() {
  9.         Connection conn = null;
  10.         try {
  11.             Class.forName("oracle.jdbc.driver.OracleDriver");
  12.             String url = "jdbc:oracle:thin:@192.168.100.251:1521:cstar";
  13.             String user = "ticket";
  14.             String pass = "ticket";
  15.             conn = DriverManager.getConnection(url, user, pass);
  16.         } catch (ClassNotFoundException e) {
  17.             e.printStackTrace();
  18.         } catch (SQLException e) {
  19.             e.printStackTrace();
  20.         }
  21.         return conn;
  22.     }
  23.     public static void main(String[] args) {
  24.         Connection conn = getConnection();
  25.         String sql = "select * from class";
  26.         PreparedStatement stmt;
  27.         try {
  28.             stmt = conn.prepareStatement(sql);
  29.             ResultSet rs = stmt.executeQuery(sql);
  30.             ResultSetMetaData data = rs.getMetaData();
  31.             while (rs.next()) {
  32.                 for (int i = 1; i <= data.getColumnCount(); i++) {
  33.                     // 获得所有列的数目及实际列数
  34.                     int columnCount = data.getColumnCount();
  35.                     // 获得指定列的列名
  36.                     String columnName = data.getColumnName(i);
  37.                     // 获得指定列的列值
  38.                     String columnValue = rs.getString(i);
  39.                     // 获得指定列的数据类型
  40.                     int columnType = data.getColumnType(i);
  41.                     // 获得指定列的数据类型名
  42.                     String columnTypeName = data.getColumnTypeName(i);
  43.                     // 所在的Catalog名字
  44.                     String catalogName = data.getCatalogName(i);
  45.                     // 对应数据类型的类
  46.                     String columnClassName = data.getColumnClassName(i);
  47.                     // 在数据库中类型的最大字符个数
  48.                     int columnDisplaySize = data.getColumnDisplaySize(i);
  49.                     // 默认的列的标题
  50.                     String columnLabel = data.getColumnLabel(i);
  51.                     // 获得列的模式
  52.                     String schemaName = data.getSchemaName(i);
  53.                     // 某列类型的精确度(类型的长度)
  54.                     int precision = data.getPrecision(i);
  55.                     // 小数点后的位数
  56.                     int scale = data.getScale(i);
  57.                     // 获取某列对应的表名
  58.                     String tableName = data.getTableName(i);
  59.                     // 是否自动递增
  60.                     boolean isAutoInctement = data.isAutoIncrement(i);
  61.                     // 在数据库中是否为货币型
  62.                     boolean isCurrency = data.isCurrency(i);
  63.                     // 是否为空
  64.                     int isNullable = data.isNullable(i);
  65.                     // 是否为只读
  66.                     boolean isReadOnly = data.isReadOnly(i);
  67.                     // 能否出现在where中
  68.                     boolean isSearchable = data.isSearchable(i);
  69.                     System.out.println(columnCount);
  70.                     System.out.println("获得列" + i + "的字段名称:" + columnName);
  71.                     System.out.println("获得列" + i + "的字段值:" + columnValue);
  72.                     System.out.println("获得列" + i + "的类型,返回SqlType中的编号:"
  73.                             + columnType);
  74.                     System.out.println("获得列" + i + "的数据类型名:" + columnTypeName);
  75.                     System.out.println("获得列" + i + "所在的Catalog名字:"
  76.                             + catalogName);
  77.                     System.out.println("获得列" + i + "对应数据类型的类:"
  78.                             + columnClassName);
  79.                     System.out.println("获得列" + i + "在数据库中类型的最大字符个数:"
  80.                             + columnDisplaySize);
  81.                     System.out.println("获得列" + i + "的默认的列的标题:" + columnLabel);
  82.                     System.out.println("获得列" + i + "的模式:" + schemaName);
  83.                     System.out
  84.                             .println("获得列" + i + "类型的精确度(类型的长度):" + precision);
  85.                     System.out.println("获得列" + i + "小数点后的位数:" + scale);
  86.                     System.out.println("获得列" + i + "对应的表名:" + tableName);
  87.                     System.out.println("获得列" + i + "是否自动递增:" + isAutoInctement);
  88.                     System.out.println("获得列" + i + "在数据库中是否为货币型:" + isCurrency);
  89.                     System.out.println("获得列" + i + "是否为空:" + isNullable);
  90.                     System.out.println("获得列" + i + "是否为只读:" + isReadOnly);
  91.                     System.out.println("获得列" + i + "能否出现在where中:"
  92.                             + isSearchable);
  93.                 }
  94.             }
  95.         } catch (SQLException e) {
  96.             System.out.println("数据库连接失败");
  97.         }
  98.     }
  99. }

结果例子如下:

3
获得列1的字段名称:CLASS_NO
获得列1的字段值:111
获得列1的类型,返回SqlType中的编号:12
获得列1的数据类型名:VARCHAR2
获得列1所在的Catalog名字:
获得列1对应数据类型的类:java.lang.String
获得列1在数据库中类型的最大字符个数:10
获得列1的默认的列的标题:CLASS_NO
获得列1的模式:
获得列1类型的精确度(类型的长度):10
获得列1小数点后的位数:0
获得列1对应的表名:
获得列1是否自动递增:false
获得列1在数据库中是否为货币型:false
获得列1是否为空:0
获得列1是否为只读:false
获得列1能否出现在where中:true
3
获得列2的字段名称:CLASS_NAME
获得列2的字段值:111
获得列2的类型,返回SqlType中的编号:12
获得列2的数据类型名:VARCHAR2
获得列2所在的Catalog名字:
获得列2对应数据类型的类:java.lang.String
获得列2在数据库中类型的最大字符个数:10
获得列2的默认的列的标题:CLASS_NAME
获得列2的模式:
获得列2类型的精确度(类型的长度):10
获得列2小数点后的位数:0
获得列2对应的表名:
获得列2是否自动递增:false
获得列2在数据库中是否为货币型:false
获得列2是否为空:1
获得列2是否为只读:false
获得列2能否出现在where中:true
3
获得列3的字段名称:TEACHER_NO
获得列3的字段值:11
获得列3的类型,返回SqlType中的编号:12
获得列3的数据类型名:VARCHAR2
获得列3所在的Catalog名字:
获得列3对应数据类型的类:java.lang.String
获得列3在数据库中类型的最大字符个数:10
获得列3的默认的列的标题:TEACHER_NO
获得列3的模式:
获得列3类型的精确度(类型的长度):10
获得列3小数点后的位数:0
获得列3对应的表名:
获得列3是否自动递增:false
获得列3在数据库中是否为货币型:false
获得列3是否为空:1
获得列3是否为只读:false
获得列3能否出现在where中:true
3
获得列1的字段名称:CLASS_NO
获得列1的字段值:222
获得列1的类型,返回SqlType中的编号:12
获得列1的数据类型名:VARCHAR2
获得列1所在的Catalog名字:
获得列1对应数据类型的类:java.lang.String
获得列1在数据库中类型的最大字符个数:10
获得列1的默认的列的标题:CLASS_NO
获得列1的模式:
获得列1类型的精确度(类型的长度):10
获得列1小数点后的位数:0
获得列1对应的表名:
获得列1是否自动递增:false
获得列1在数据库中是否为货币型:false
获得列1是否为空:0
获得列1是否为只读:false
获得列1能否出现在where中:true
3
获得列2的字段名称:CLASS_NAME
获得列2的字段值:222
获得列2的类型,返回SqlType中的编号:12
获得列2的数据类型名:VARCHAR2
获得列2所在的Catalog名字:
获得列2对应数据类型的类:java.lang.String
获得列2在数据库中类型的最大字符个数:10
获得列2的默认的列的标题:CLASS_NAME
获得列2的模式:
获得列2类型的精确度(类型的长度):10
获得列2小数点后的位数:0
获得列2对应的表名:
获得列2是否自动递增:false
获得列2在数据库中是否为货币型:false
获得列2是否为空:1
获得列2是否为只读:false
获得列2能否出现在where中:true
3
获得列3的字段名称:TEACHER_NO
获得列3的字段值:22
获得列3的类型,返回SqlType中的编号:12
获得列3的数据类型名:VARCHAR2
获得列3所在的Catalog名字:
获得列3对应数据类型的类:java.lang.String
获得列3在数据库中类型的最大字符个数:10
获得列3的默认的列的标题:TEACHER_NO
获得列3的模式:
获得列3类型的精确度(类型的长度):10
获得列3小数点后的位数:0
获得列3对应的表名:
获得列3是否自动递增:false
获得列3在数据库中是否为货币型:false
获得列3是否为空:1
获得列3是否为只读:false
获得列3能否出现在where中:true
3
获得列1的字段名称:CLASS_NO
获得列1的字段值:333
获得列1的类型,返回SqlType中的编号:12
获得列1的数据类型名:VARCHAR2
获得列1所在的Catalog名字:
获得列1对应数据类型的类:java.lang.String
获得列1在数据库中类型的最大字符个数:10
获得列1的默认的列的标题:CLASS_NO
获得列1的模式:
获得列1类型的精确度(类型的长度):10
获得列1小数点后的位数:0
获得列1对应的表名:
获得列1是否自动递增:false
获得列1在数据库中是否为货币型:false
获得列1是否为空:0
获得列1是否为只读:false
获得列1能否出现在where中:true
3
获得列2的字段名称:CLASS_NAME
获得列2的字段值:333
获得列2的类型,返回SqlType中的编号:12
获得列2的数据类型名:VARCHAR2
获得列2所在的Catalog名字:
获得列2对应数据类型的类:java.lang.String
获得列2在数据库中类型的最大字符个数:10
获得列2的默认的列的标题:CLASS_NAME
获得列2的模式:
获得列2类型的精确度(类型的长度):10
获得列2小数点后的位数:0
获得列2对应的表名:
获得列2是否自动递增:false
获得列2在数据库中是否为货币型:false
获得列2是否为空:1
获得列2是否为只读:false
获得列2能否出现在where中:true
3
获得列3的字段名称:TEACHER_NO
获得列3的字段值:11
获得列3的类型,返回SqlType中的编号:12
获得列3的数据类型名:VARCHAR2
获得列3所在的Catalog名字:
获得列3对应数据类型的类:java.lang.String
获得列3在数据库中类型的最大字符个数:10
获得列3的默认的列的标题:TEACHER_NO
获得列3的模式:
获得列3类型的精确度(类型的长度):10
获得列3小数点后的位数:0
获得列3对应的表名:
获得列3是否自动递增:false
获得列3在数据库中是否为货币型:false
获得列3是否为空:1
获得列3是否为只读:false
获得列3能否出现在where中:true

分享到:
评论

相关推荐

    JAVA数据库编程实例随书源码

    5. 第8章和第9章可能涵盖更进阶的主题,如批处理操作、结果集的遍历和管理,以及使用ResultSetMetaData获取元数据信息。 6. 第10章通常会讨论一些高级话题,如数据库连接池的使用,它可以提高性能并优化资源管理,...

    jdbc 编程实例

    在“JDBC编程实例”中,可能会涵盖如何使用JDBC连接MySQL数据库,执行基本的CRUD操作,处理批量操作,以及事务管理和连接池的使用。这些实例有助于巩固理论知识,并为实际项目提供实践指导。 总结,JDBC是Java...

    JAVA100例之实例57 结果集元数据

    本实例57将深入探讨如何利用ResultSetMetaData对象来获取这些重要信息。 当你通过Statement或PreparedStatement对象执行SQL查询后,会得到一个ResultSet对象,它包含了查询返回的所有行数据。ResultSetMetaData对象...

    java数据库开发实例教案

    第五个实例可能涉及到“结果集处理”,包括迭代遍历`ResultSet`,处理多行或多列的数据,以及使用`ResultSetMetaData`获取元数据信息。 第六至第八个案例可能进一步深化,比如“存储过程的调用”、“预编译的SQL...

    java 调用存储过程 实例

    本实例将深入探讨如何使用Java来调用Oracle数据库中的存储过程。 首先,我们需要了解存储过程的基本概念。存储过程是预编译的SQL语句集合,存储在数据库服务器上,可以视为可重复使用的函数,提高了代码的重用性和...

    java程序读取表的字段及类型实例

    ### Java程序读取Oracle表的字段及类型实例 在Java编程中,经常需要与数据库进行交互,例如查询、更新或删除数据等操作。而在这些操作之前,了解表结构(包括字段名称及其对应的类型)是非常重要的一步。这有助于...

    jdbc实例教程

    **JDBC实例教程** JDBC(Java Database Connectivity)是Java编程语言中用于访问数据库的标准Java API,它允许Java开发者在程序中执行SQL语句,进行数据的增删查改操作,以及获取数据库元数据和管理事务。本教程将...

    Java操作Mysql实例

    根据提供的信息,我们可以总结出以下关于“Java操作MySQL实例”的详细知识点: ### 一、环境配置 #### MySQL数据库版本: - 版本:4.1.11 - 下载地址:[http://dev.mysql.com/downloads/mysql/4.1.html]...

    java 代码笔记 2010-06-23 对ResultSet()的几个常用操作,实例。

    ResultSetMetaData meta = rs.getMetaData(); int columnCount = meta.getColumnCount(); for (int i = 1; i ; i++) { if ("columnName".equals(meta.getColumnName(i))) { // 列存在,执行相应操作 } } ``` 5. ...

    Java中Boolean与字符串或者数字1和0的转换实例

    在上面的代码中,我们使用ResultSetMetaData来获取数据库字段信息,例如获取字段数量、字段名称等。 四、使用反射机制来映射Boolean类型字段 在Java中,我们可以使用反射机制来映射Boolean类型字段。例如: ```...

    java如何获得数据库表中各字段的字段名

    然后利用该结果集的`getMetaData()`方法得到一个`ResultSetMetaData`实例,从而进一步获取字段名称等相关信息。 #### 示例代码解析 以下是对给定示例代码的详细解释: 1. **加载驱动程序**: ```java String ...

    表字段描述依赖包

    在ORMlite框架中,当执行SQL查询并获取ResultSet时,可以使用ORMlite提供的工具方法来获取ResultSetMetaData。这个信息对于理解数据库表结构至关重要,比如字段名、字段类型(如整型、字符串、日期等)、字段顺序...

    Java数据库编程宝典2

    10.5 使用ResultSetMetaData 10.6 小结 第3部分 三层Web站点与JDBC 第11章 构建会员Web站点 11.1 设计一个多层系统 11.2 功能性需求 11.3 设计数据库 11.3.1 处理会员登录 11.3.2 会员注册 11.3.3 数据...

    Java数据库编程宝典4

    10.5 使用ResultSetMetaData 10.6 小结 第3部分 三层Web站点与JDBC 第11章 构建会员Web站点 11.1 设计一个多层系统 11.2 功能性需求 11.3 设计数据库 11.3.1 处理会员登录 11.3.2 会员注册 11.3.3 数据...

    Java数据库编程宝典1

    10.5 使用ResultSetMetaData 10.6 小结 第3部分 三层Web站点与JDBC 第11章 构建会员Web站点 11.1 设计一个多层系统 11.2 功能性需求 11.3 设计数据库 11.3.1 处理会员登录 11.3.2 会员注册 11.3.3 数据...

    Java数据库编程宝典3

    10.5 使用ResultSetMetaData 10.6 小结 第3部分 三层Web站点与JDBC 第11章 构建会员Web站点 11.1 设计一个多层系统 11.2 功能性需求 11.3 设计数据库 11.3.1 处理会员登录 11.3.2 会员注册 11.3.3 数据...

    Android+阿里云数据库,实现安卓云数据库,包括mysql包

    - 使用`ResultSetMetaData`获取列元数据,了解查询结果的结构。 6. **关闭连接**: - 记得在操作完成后关闭`ResultSet`、`Statement`和`Connection`,以释放资源。 7. **Android应用的安全性**: - 由于直接在...

Global site tag (gtag.js) - Google Analytics