使用DatabaseMetaData接口查询GBase 8s数据库结构

Java程序中允许使用DatabaseMetaData接口查询数据库结构,以下是使用该接口查询GBase 8s数据库的示例代码。
更换驱动信息,同样适用于GBase 8t/IBM Informix。

package testGBasedbt;

import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.ResultSet;

public class TestDBMetadata {

    public static void main(String[] args) {
        
        testDBMetadata();

    }
    
    public static void testDBMetadata() {   
        
        String url = "jdbc:gbasedbt-sqli://192.168.80.100:9000/testdb:GBASEDBTSERVER=gbasedbt;DB_LOCALE=en_US.utf8;CLIENT_LOCALE=en_US.utf8;IFX_USE_STRENC=true";   
        String user = "gbasedbt";   
        String pass = "123456"; 
        
        try {   
  
            Class.forName("com.gbasedbt.jdbc.IfxDriver").newInstance();   
            Connection conn = DriverManager.getConnection(url, user, pass);   
            DatabaseMetaData metadata = conn.getMetaData(); 
            
            System.out.println("数据库已知的用户: " + metadata.getUserName());   
            System.out.println("数据库的系统函数的逗号分隔列表: " + metadata.getSystemFunctions());   
            System.out.println("数据库的时间和日期函数的逗号分隔列表: " + metadata.getTimeDateFunctions());   
            System.out.println("数据库的字符串函数的逗号分隔列表: " + metadata.getStringFunctions());   
            System.out.println("数据库供应商用于 'schema'的首选术语: " + metadata.getSchemaTerm());   
            System.out.println("数据库URL: " + metadata.getURL());   
            System.out.println("是否允许只读: " + metadata.isReadOnly());   
            System.out.println("数据库的产品名称: " + metadata.getDatabaseProductName());   
            System.out.println("数据库的版本: " + metadata.getDatabaseProductVersion());   
            System.out.println("驱动程序的名称: " + metadata.getDriverName());   
            System.out.println("驱动程序的版本: " + metadata.getDriverVersion());   
               
            System.out.println();   
            System.out.println("数据库中使用的表类型: ");   
            ResultSet rs = metadata.getTableTypes();   
            while (rs.next()) {   
                System.out.println(rs.getString(1));   
            }   
            rs.close();   
               
            System.out.println();  
            
            /* 
             * 获取指定的数据库的所有表的类型,
             * getTables()的第一个参数就:数据库名称 ,第二个参数:schema,等效于表的所有者,第三个参数:表模式、表名称,可以使用表达式,第四个参数:数组类型,表的类型
             */  
            System.out.println("获取指定的数据库的所有表的类型");   
            //ResultSet rs1 = metadata.getTables("testdb", null, null, null); 
            String tmptype[] = {"TABLE"};            
            ResultSet rs1 = metadata.getTables("testdb", "gbasedbt", "%1%", tmptype);
            while (rs1.next()) {   
                System.out.println("数据库名: " + rs1.getString(1));   
                System.out.println("表名         : " + rs1.getString(3));   
                System.out.println("类型         : " + rs1.getString(4)); 
                System.out.println();
            }   
            rs1.close();   
               
            System.out.println();  
            
            /*
             * 获取指定的数据库的表的主键,
             * getPrimaryKeys()的第一个参数:数据库名称,第二个参数:schema,等效于表的所有者,第三个参数:表名称
             */
            System.out.println("获取指定的数据库的表的主键: "); 
            ResultSet rs2 = metadata.getPrimaryKeys("testdb", null, "t1");   
            while (rs2.next()) {   
                System.out.println("主键字段名称: "+ rs2.getString(4));   
            }   
            rs2.close();   
               
            System.out.println(); 
            
            /*
             * 获取指定的数据库的表的索引
             * getIndexInfo()的第一个参数:数据库名称,第二个参数:schema,等效于表的所有者,第三个参数:表名称
             * 第四个参数:是否仅返回唯一索引,第五个参数:是否返回准确结果
             */
            System.out.println("获取指定的数据库的表的索引: ");   
            ResultSet rs3 = metadata.getIndexInfo("testdb", null, "t1", false, true);   
            while (rs3.next()) {   
                System.out.println("数据库名: "+ rs3.getString(1));   
                System.out.println("表模式: "+ rs3.getString(2));   
                System.out.println("表名称: "+ rs3.getString(3));   
                System.out.println("索引值是否可以不唯一: "+ rs3.getString(4));   
                System.out.println("索引类别: "+ rs3.getString(5));   
                System.out.println("索引名称: "+ rs3.getString(6));   
                System.out.println("索引类型: "+ rs3.getString(7));   
                System.out.println("索引中的列序列号: "+ rs3.getString(8));   
                System.out.println("列名称: "+ rs3.getString(9));   
                System.out.println("列排序序列: "+ rs3.getString(10));   
                System.out.println("TYPE为 tableIndexStatistic时它是表中的行数否则它是索引中唯一值的数量: "+ rs3.getString(11));   
                System.out.println("TYPE为 tableIndexStatisic时它是用于表的页数否则它是用于当前索引的页数: "+ rs3.getString(12));   
                System.out.println("过滤器条件: "+ rs3.getString(13)); 
                System.out.println();
            }   
            rs3.close();   
               
        } catch (Exception e) {   
            e.printStackTrace();   
        }   
    }

}

运行结果类似以下:

数据库已知的用户: gbasedbt
数据库的系统函数的逗号分隔列表: avg,max,min,sum,count,range,stdev,variance,trim,hex,filetoblob,filetoclob,lotofile,lotocopy
数据库的时间和日期函数的逗号分隔列表: date,day,month,weekday,year,extend,mdy
数据库的字符串函数的逗号分隔列表: trunc,length
数据库供应商用于 'schema'的首选术语: user
数据库URL: jdbc:gbasedbt-sqli://192.168.80.100:9000/testdb:GBASEDBTSERVER=gbasedbt;DB_LOCALE=en_US.utf8;CLIENT_LOCALE=en_US.utf8;IFX_USE_STRENC=true
是否允许只读: false
数据库的产品名称: GBase Server
数据库的版本: 12.10.FC4G1AEE
驱动程序的名称: GBase JDBC Driver for GBase Server
驱动程序的版本: 4.10.JC4G1N999

数据库中使用的表类型: 
SYSTEM TABLE
TABLE
VIEW

获取指定的数据库的所有表的类型
数据库名: testdb
表名         : t1
类型         : TABLE


获取指定的数据库的表的主键: 
主键字段名称: col1

获取指定的数据库的表的索引: 
数据库名: testdb
表模式: gbasedbt
表名称: t1
索引值是否可以不唯一: 0
索引类别: gbasedbt
索引名称: 100_3
索引类型: 3
索引中的列序列号: 1
列名称: col1
列排序序列: null
TYPE为 tableIndexStatistic时它是表中的行数否则它是索引中唯一值的数量: 0
TYPE为 tableIndexStatisic时它是用于表的页数否则它是用于当前索引的页数: 0
过滤器条件: null

数据库名: testdb
表模式: gbasedbt
表名称: t1
索引值是否可以不唯一: 1
索引类别: gbasedbt
索引名称: ix_t1
索引类型: 3
索引中的列序列号: 1
列名称: col2
列排序序列: null
TYPE为 tableIndexStatistic时它是表中的行数否则它是索引中唯一值的数量: 0
TYPE为 tableIndexStatisic时它是用于表的页数否则它是用于当前索引的页数: 0
过滤器条件: null

标签: databasemetadata, 元数据, jdbc

添加新评论