jdbc 得到表结构、主键

    xiaoxiao2021-12-14  23

    假设有个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(nullnull, "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网站) 

    转载请注明原文地址: https://ju.6miu.com/read-962982.html

    最新回复(0)