java 查詢oracle數(shù)據(jù)庫所有表DatabaseMetaData的用法(詳解)
一 . 得到這個對象的實例
Connection con ; con = DriverManager.getConnection(url,userName,password); DatabaseMetaData dbmd = con.getMetaData();
二. 方法getTables的用法
原型:
ResultSet DatabaseMetaData.getTables(String catalog,String schema,String tableName,String []type)
此方法可返回結(jié)果集合ResultSet ,結(jié)果集中有5列, 超出會報越界異常
功能描述:得到指定參數(shù)的表信息
參數(shù)說明:
參數(shù):catalog:目錄名稱,一般都為空.
參數(shù):schema:數(shù)據(jù)庫名,對于oracle來說就用戶名
參數(shù):tablename:表名稱
參數(shù):type :表的類型(TABLE | VIEW)
注意:在使用過程中,參數(shù)名稱必須使用大寫的。否則得到什么東西。
三. 方法getColumns的用法
功能描述:得到指定表的列信息。
原型:
ResultSet DatabaseMetaData getColumns(String catalog,String schema,String tableName,String columnName)
參數(shù)說明:
參數(shù)catalog : 類別名稱
參數(shù)schema : 用戶方案名稱
參數(shù)tableName : 數(shù)據(jù)庫表名稱
參數(shù)columnName : 列名稱
四、方法getPrimaryKeys的用法
功能描述:得到指定表的主鍵信息。
原型:
ResultSet DatabaseMetaData getPrimaryKeys(String catalog,String schema,String tableName)
參數(shù)說明:
參數(shù)catalog : 類別名稱
參數(shù)schema : 用戶方案名稱
參數(shù)tableName : 數(shù)據(jù)庫表名稱
備注:一定要指定表名稱,否則返回值將是什么都沒有。
五、方法.getTypeInfo()的用法
功能描述:得到當前數(shù)據(jù)庫的數(shù)據(jù)類型信息。
六、方法getExportedKeys的用法
功能描述:得到指定表的外鍵信息。
參數(shù)描述:
參數(shù)catalog : 類別名稱
參數(shù)schema : 用戶方案名稱
參數(shù)tableName : 數(shù)據(jù)庫表名稱
下面以MySQL和Oracle為例來講解這個兩個參數(shù)。
Oracle和MySQL數(shù)據(jù)的組織結(jié)構(gòu)是完全不同,直觀表象上,表和視圖的掛接途徑不一樣,在Oracle中,采取的是分用戶管理機制,表和視圖掛接在某個用戶下,此時用戶會成為Oracle的一個”模式(schema)”;而在MySQL中表和視圖是直接掛接在數(shù)據(jù)庫下的。這樣,在Oralce中獲取catalog得到的是null,獲取schema得到大寫的是用戶名稱列表。而在MySQL中得到的catalog是數(shù)據(jù)庫名稱列表,而schema是null。讀者可以通過DatabaseMetaData提供的如下兩個方法進行測試,他們返回的都是ResultSet數(shù)據(jù)類型。
//獲取類別定義
rs=dbmd.getCatalogs();
//獲取模式定義
rs=dbmd.getSchemas();
基于上述分析:
如果數(shù)據(jù)庫為MySQL:那么第一個參數(shù)catalog,可以是數(shù)據(jù)庫的名稱,當該項為null時候,為Url串中指定的數(shù)據(jù)庫名稱,第二個參數(shù)schema,填入null;
如果數(shù)據(jù)庫為Oralce: 那么第一個參數(shù)catalog,為null,第二個參數(shù)schema,填入大寫的用戶名稱例如”SCOTT”,如果該項目為null,那么查詢范圍為所有的模式用戶。
返回值分析
方法getTables返回值是一個結(jié)果集(ResultSet)類型,對于該結(jié)果集中的信息,到JDK1.5預(yù)留了20多個項目用來描述表的相關(guān)信息,但是,并不是每個數(shù)據(jù)都會將這20多個項目返回的. 我們能夠常用到的有如下的四個項目:
TABLE_SCHEM:對于Oracle而言,是大寫的用戶名稱,對MySQL而言為null 。
TABLE_NAME:表的名稱 。
TABLE_CAT=對Oracle而言為null,對MySQL而言是數(shù)據(jù)庫名稱 。
TABLE_TYPE=表的類型,依據(jù)第四個參數(shù)types數(shù)組中的某一項,用以表和視圖。
import java.sql.Connection; import java.sql.DatabaseMetaData; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ArrayList; import java.util.List; public class dababase { private String url="jdbc:oracle:thin:@localhost:1521:zhyl"; //服務(wù)器地址:,端口號:1521,數(shù)據(jù)庫實例名字:zhyl。 private String username="andatabase"; private String pw="oracl"; private Connection conn=null; //用戶名字和密碼是自己建立的。 public Connection OpenConn(){ try { Class.forName("oracle.jdbc.driver.OracleDriver"); try { conn=DriverManager.getConnection(url,username,pw); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } return conn; } public ResultSet executeQuery(String sql){ dababase db = new dababase(); ResultSet rs = null; Connection con =db.OpenConn(); try { Statement sm = con.createStatement(); rs = sm.executeQuery(sql); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return rs; } public void close(){ try { conn.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } // 獲取數(shù)據(jù)庫中所有表的表名,并添加到列表結(jié)構(gòu)中。 public List getTableNameList(Connection conn) throws SQLException { DatabaseMetaData dbmd = conn.getMetaData(); //訪問當前用戶ANDATABASE下的所有表 ResultSet rs = dbmd.getTables("null", "ANDATABASE", "%", new String[] { "TABLE" }); //System.out.println("kkkkkk"+dbmd.getTables("null", "%", "%", new String[] { "TABLE" })); List tableNameList = new ArrayList(); while (rs.next()) { tableNameList.add(rs.getString("TABLE_NAME")); } return tableNameList; } // 獲取數(shù)據(jù)表中所有列的列名,并添加到列表結(jié)構(gòu)中。 public List getColumnNameList(Connection conn, String tableName) throws SQLException { DatabaseMetaData dbmd = conn.getMetaData(); ResultSet rs = dbmd.getColumns(null, "%", tableName, "%"); List columnNameList = new ArrayList(); while (rs.next()) { columnNameList.add(rs.getString("COLUMN_NAME")); } return columnNameList; } public static void main(String s[]) throws SQLException { dababase dbConn = new dababase(); Connection conn = dbConn.OpenConn(); if(conn==null) System.out.println("連接失敗"); else System.out.println("連接成功"); try { List tableList = dbConn.getTableNameList(conn);//取出當前用戶的所有表 //List tableList = dbConn.getColumnNameList(conn, "LOGIN");//表名稱必須是大寫的,取出當前表的所有列 System.out.println(tableList.size()); for (Object object : tableList) { String ss=(String)object; System.out.println(ss); } } catch (SQLException e) { e.printStackTrace(); } finally { if (conn != null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } } }
以上就是小編為大家?guī)淼膉ava 查詢oracle數(shù)據(jù)庫所有表DatabaseMetaData的用法(詳解)全部內(nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
Spring Boot 添加MySQL數(shù)據(jù)庫及JPA實例
本篇文章主要介紹了Spring Boot 添加MySQL數(shù)據(jù)庫及JPA,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03Java連接PostgreSql數(shù)據(jù)庫及基本使用方式
這篇文章主要介紹了Java連接PostgreSql數(shù)據(jù)庫及基本使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03永中文檔在線轉(zhuǎn)換服務(wù)Swagger調(diào)用說明
這篇文章主要為大家介紹了永中文檔在線轉(zhuǎn)換服務(wù)Swagger調(diào)用說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06解決idea刪除模塊后重新創(chuàng)建顯示該模塊已經(jīng)被注冊的問題
這篇文章主要介紹了解決idea刪除模塊后重新創(chuàng)建顯示該模塊已經(jīng)被注冊的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02SpringBoot集成SpringSecurity和JWT做登陸鑒權(quán)的實現(xiàn)
這篇文章主要介紹了SpringBoot集成SpringSecurity和JWT做登陸鑒權(quán)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04