• jdbc 得到表结构、主键


    jdbc 得到表结构、主键

    标签: jdbctablenullschema数据库mysql
     分类:

    假设有个con 
    DatabaseMetaData dbmd = con.getMetaData(); 
    rs = dbmd.getColumns(con.getCatalog(), schema, tableName, null); 
    rs.getString(DATA_TYPE) Java.sql.Types 的 SQL 类型 
    rs.getString(COLUMN_SIZE) 列的大小。对于 char 或 date 类型,列的大小是最大字符数,对于 numeric 和 decimal 类型,列的大小就是精度。 
    rs.getString(DECIMAL_DIGITS) 小数部分的位数

    JDBC中通过MetaData来获取具体的表的相关信息。可以查询数据库中的有哪些表,表有哪些字段,字段的属性等等。MetaData中通过一系列getXXX函数,将这些信息存放到ResultSet里面,然后返回给用户。关于MetaData的说明网上也有不少,这里我只是从我自身学习的角度来记录一下简单使用JDBC以及获取数据表相关信息的方法。 
    首先,http://hometown.aol.com/kgb1001001/Articles/JDBCMetadata/JDBC_Metadata.htm 这里有篇名字叫做《Understanding JDBC MetaData》的文章,讲解得不错。

    下面就是我的JDBC下的获取表信息的代码了。我是以MySQL 5.0作为测试平台的。

    1. JDBC连接MYSQL的代码很标准,很简单。 
    class.forName("com.mysql.jdbc.Driver").newInstance(); 
    Connection conn = DriverManager 
    .getConnection("jdbc:mysql://localhost/test?user=root&password=123456");

    2. 下面就是获取表的信息。 
    m_DBMetaData = m_Connection.getMetaData(); 
    ResultSet tableRet = m_DBMetaData.getTables(null, "%",m_TableName,new String[]{"TABLE"}); 
    其中"%"就是表示*的意思,也就是任意所有的意思。其中m_TableName就是要获取的数据表的名字,如果想获取所有的表的名字,就可以使用"%"来作为参数了。

    3. 提取表的名字。 
    while(tableRet.next) System.out.println(tableRet.getString("TABLE_NAME"));

    通过getString("TABLE_NAME"),就可以获取表的名字了。 
    从这里可以看出,前面通过getTables的接口的返回,JDBC是将其所有的结果,保存在一个类似table的内存结构中,而其中TABLE_NAME这个名字的字段就是每个表的名字。

    4. 提取表内的字段的名字和类型 
    String columnName; 
    String columnType; 
    ResultSet colRet = m_DBMetaData.getColumns(null,"%", m_TableName,"%"); 
    while(colRet.next()) { 
    columnName = colRet.getString("COLUMN_NAME"); 
    columnType = colRet.getString("TYPE_NAME"); 
    int datasize = colRet.getInt("COLUMN_SIZE"); 
    int digits = colRet.getInt("DECIMAL_DIGITS"); 
    int nullable = colRet.getInt("NULLABLE"); 
    System.out.println(columnName+" "+columnType+" "+datasize+" "+digits+" "+ 
    nullable); 
    }

    JDBC里面通过getColumns的接口,实现对字段的查询。跟getTables一样,"%"表示所有任意的(字段),而m_TableName就是数据表的名字。

    getColumns的返回也是将所有的字段放到一个类似的内存中的表,而COLUMN_NAME就是字段的名字,TYPE_NAME就是数据类型,比如"int","int unsigned"等等,COLUMN_SIZE返回整数,就是字段的长度,比如定义的int(8)的字段,返回就是8,最后NULLABLE,返回1就表示可以是Null,而0就表示Not Null。
    -------------------
    大多数数据库有许多主键,但是在一个表中不允许两条记录的同一个主键具有相同的值。可以使用Java Database Connectivity(JDBC)来判断一个数据表的主键。 
      JDBC具有强大的元数据处理能力。java.sql.Connection类和java.sql.ResultSet类可以通过调用其getMetaData方法进行反射,例如: 
      // 对java.sql中所有的类 
      Connection connection = ..... 
      DatabaseMetaData dbMeta = connection.getMetaData(); 
      ResultSet rset = ..... 
      ResultSetMetaData rsMeta = rset.getMetaData(); 
      java.sql.DatabaseMetaData类包含一个查找数据表主键的方法。你需要知道表的名字,catalog名和schema名。如果不知道catalog和schema,那么你可以不使用它们而输入“null”。例如: 
      // 查找一个名字为“Comment”的表的主键 
      // 没有catalog或schema,都设置为null 
      ResultSet pkRSet = dbMeta.getPrimaryKeys(null, null, "Comment"); 
      while( pkRSet.next() ) { 
      System.err.println("****** Comment ******"); 
      System.err.println("TABLE_CAT : "+pkRSet.getObject(1)); 
      System.err.println("TABLE_SCHEM: "+pkRSet.getObject(2)); 
      System.err.println("TABLE_NAME : "+pkRSet.getObject(3)); 
      System.err.println("COLUMN_NAME: "+pkRSet.getObject(4)); 
      System.err.println("KEY_SEQ : "+pkRSet.getObject(5)); 
      System.err.println("PK_NAME : "+pkRSet.getObject(6)); 
      System.err.println("****** ******* ******"); 
      } 
      在这个例子中表“Comment”具有一个叫做“comment_id”的主键。 
      下面是上面这些代码在MySQL上的输出: 
      ****** Comment ****** 
      TABLE_CAT : 
      TABLE_SCHEM: 
      TABLE_NAME : Comment 
      COLUMN_NAME: column_id 
      KEY_SEQ : 1 
      PK_NAME : column_id 
      ****** ******* ****** 
      存在PK_NAME的原因是有时会为一个主键使用列名之外的名字。而KEY_SEQ表示了主键的顺序位置。有些使用字母顺序保存主键的数据库会为KEY_SEQ返回0。 
      当创建通用的数据库应用时,查找一个表的主键是很基本的。JDBC的MetaData类提供了所需的数据库反射机制,从而使得这些应用的实现成为可能。 
      (本文是为ZDNet翻译的系列文章之一,原文已经发表在ZDNet网站) 

     
     
  • 相关阅读:
    08 字体属性设置-font-family
    函数-函数进阶-生成器调用方法
    函数-函数进阶-斐波那契
    函数-函数进阶-列表生成式
    函数-函数进阶-装饰器带参数2
    函数-函数进阶-装饰带参数的函数
    函数-函数进阶-装饰器流程分析
    函数-函数进阶-装饰器
    函数-函数进阶-闭包
    函数-函数进阶-作用域的查找空间
  • 原文地址:https://www.cnblogs.com/developer-ios/p/6106104.html
Copyright © 2020-2023  润新知