oracle中如何查詢所有用戶表的表名、主鍵名稱、索引及外鍵等
1、查找表的所有索引(包括索引名,類型,構成列):
select t.*,i.index_type from user_ind_columns t,user_indexes i where t.index_name = i.index_name and t.table_name = i.table_name and t.table_name = 要查詢的表
2、查找表的主鍵(包括名稱,構成列):
select cu.* from user_cons_columns cu, user_constraints au where cu.constraint_name = au.constraint_name and au.constraint_type = 'P' and au.table_name = 要查詢的表
3、查找表的唯一性約束(包括名稱,構成列):
select column_name from user_cons_columns cu, user_constraints au where cu.constraint_name = au.constraint_name and au.constraint_type = 'U' and au.table_name = 要查詢的表
4、查找表的外鍵(包括名稱,引用表的表名和對應的鍵名,下面是分成多步查詢):
select * from user_constraints c where c.constraint_type = 'R' and c.table_name = 要查詢的表
查詢外鍵約束的列名:
select * from user_cons_columns cl where cl.constraint_name = 外鍵名稱
查詢引用表的鍵的列名:
select * from user_cons_columns cl where cl.constraint_name = 外鍵引用表的鍵名
5、查詢表的所有列及其屬性
select t.*,c.COMMENTS from user_tab_columns t,user_col_comments c where t.table_name = c.table_name and t.column_name = c.column_name and t.table_name = 要查詢的表
附:oracle中查看一張表是否有主鍵,主鍵在哪個字段上
1. 利用Oracle中系統(tǒng)自帶的兩個視圖可以實現(xiàn)查看表中主鍵信息,
語句如下:
select a.constraint_name, a.column_name from user_cons_columns a, user_constraints b where a.constraint_name = b.constraint_name and b.constraint_type = 'P' and a.table_name = '大寫的表名'
查看表的主鍵約束名稱,以及主鍵約束的字段名稱。如果沒有,則返回空
2. 順便給出創(chuàng)建主鍵和刪除主鍵的sql
向表中添加主鍵
alter table 表名 add constraint 主鍵名 primary key(列名);
刪除表中已有的主鍵約束
???????alter table 表名 drop constraint 主鍵名;
總結
到此這篇關于oracle中如何查詢所有用戶表的表名、主鍵名稱、索引及外鍵等的文章就介紹到這了,更多相關oracle查詢所有表名主鍵名稱索引內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
oracle 監(jiān)聽 lsnrctl 命令 (推薦)
這篇文章主要介紹了oracle 監(jiān)聽 lsnrctl 命令 ,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-03-03
Oracle帶輸入輸出參數(shù)存儲過程(包括sql分頁功能)
這篇文章主要介紹了Oracle帶輸入輸出參數(shù)存儲過程(包括sql分頁功能)的相關知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-10-10
Oracle除去數(shù)據(jù)中的換行符以免讀取出現(xiàn)問題
將整條數(shù)據(jù)取出,并用特殊符號分割,如果數(shù)據(jù)出現(xiàn)換行的情況,那么讀取時就有問題,這時就可以采用下面的方法來去除2014-07-07
oracle表空間的創(chuàng)建及dmp 文件的導入(推薦)
這篇文章主要介紹了oracle表空間的創(chuàng)建及dmp 文件的導入,需非常不錯,具有參考借鑒價值,要的朋友可以參考下2017-08-08
查詢Oracle數(shù)據(jù)庫表是否被鎖的實現(xiàn)方式
本文介紹了查詢Oracle數(shù)據(jù)庫表是否被鎖的方法,包括查詢鎖表的會話、人員信息,根據(jù)object_id查詢表名,以及根據(jù)會話ID查詢和停止本地進程,同時,還提到在嘗試加鎖之前判斷記錄是否已經(jīng)被鎖定,以避免鎖定已鎖定的記錄2025-02-02

