jdbc读取数据库里的信息--表信息

 

我们使用jdbc除了要对我们的数据进行操作,有时候对表和数据库的信息也可能有时需要一定的操作的。这里我们就会使用到 
DatabaseMetaData dbMeta = conn.getMetaData(); 这个重要的meta类

 

根据这里的DatabaseMetaData类,我们不仅可以拿到基本的database的信息,还可以获得很多数据库内部的对象的信息,这里颇有些类似我们常说的数据库字典表哟。

 

下面我们就一下看看我们可以读到的信息

 

可读信息之一-----表信息

 

读取所有的表 
dbMeta.getTables(catalog, schemaPattern, tableNamePattern, types)


这个API就可以获得所有的表的信息。这里的catalog和schemaPattern, tablenamePattern都可以为null,就是读取当前的schema的概念,由于每个数据库里对schema的概念都不尽相同,所以这里需要根据你具体的数据库来进行调试。

 

我这里是mysql上的一段代码如下

 

引用:
ResultSet tblRSet = dbMeta.getTables(null, null, null, null);  


System.out.println(" ********************* All Tables *********************");  

while(tblRSet.next())  
{  
System.out.print(tblRSet.getObject("TABLE_CAT")+" ");  
System.out.print(tblRSet.getObject("TABLE_SCHEM")+" ");  
System.out.print(tblRSet.getObject("TABLE_NAME")+" ");  
System.out.print(tblRSet.getObject("TABLE_TYPE")+" ");  
System.out.print(tblRSet.getObject("REMARKS")+" ");  

System.out.println();  
}

 

结果

 

poc null account TABLE 
poc null account_update_log TABLE 
poc null ebs_sku TABLE 
poc null ebs_skuitem TABLE 
poc null ebs_skuitem_his TABLE 
poc null favorite TABLE 
poc null machine_status TABLE 
poc null seq_sequence TABLE 
poc null student TABLE 
poc null stufav TABLE 
poc null test_1 TABLE 
poc null test_if TABLE 
poc null test_parent TABLE 
poc null test_parent2 TABLE 
poc null test_ref TABLE 
poc null user TABLE 
poc null test_view VIEW

 

这里的

TABLE_CAT

TABLE_SCHEM

TABLE_NAME

TABLE_TYPE

REMARKS就不做详细解释了,

 

需要注意的是TABLE_TYPE,由于每个数据库的功能各不相同,所以支持的对象类型也不尽相同。 你可以用

 

result = dbMeta.getTableTypes();

 

while(result.next())
 {
            System.out.print(result.getObject("
TABLE_TYPE ")+" ");

}

 

TABLE
VIEW
LOCAL TEMPORARY

 

获取table type来进行判断。

 

这里还不错,一个标准的api使我们不需要针对每种数据库的数据字典操作了。

 

下一个介绍 jdbc读取数据库里的信息--读取主键,外键信息。




 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

inthirties

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值