1、用sql查表
公司主營(yíng)業(yè)務(wù):成都做網(wǎng)站、網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出廣信免費(fèi)做網(wǎng)站回饋大家。
查表的時(shí)候需要用到user_tables、all_tables,user_tables查出來的是該用戶擁有的表,all_tables查出來的是所有用戶的表。
2、用sql查表的字段
查表的字段需要用到user_tab_columns、all_tab_columns,一樣的前者只能查到該用戶擁有的表,后者可以查詢所有用戶的表。
3、其他
與上面類似的還有查詢對(duì)象(user_objects、all_objects)、索引(user_indexes、all_indexes)、約束(user_constraints、all_constraints)等。
至于到底怎么查,先用select * from XXX查看表的信息,然后看下就知道了。比如查一個(gè)system表dba_data_files的字段,可以用select * from all_tab_columns where table_name = 'DBA_DATA_FILES',注意表名大寫。
2014-11-04補(bǔ)充:
下列列出一些比較重要的數(shù)據(jù)字典:
DBA_TABLES:描述數(shù)據(jù)庫(kù)中所有相關(guān)的表。
DBA_ALL_TABLES:描述數(shù)據(jù)庫(kù)中所有的對(duì)象以及相關(guān)的表。
USER_TABLES:描述數(shù)據(jù)庫(kù)中當(dāng)前用戶擁有的相關(guān)的表。
USER_ALL_TABLES:描述數(shù)據(jù)庫(kù)中當(dāng)前用戶擁有的對(duì)象以及相關(guān)的表。
ALL_TABLES:描述數(shù)據(jù)庫(kù)中所有的用戶可以訪問的相關(guān)的表。
ALL_ALL_TABLES:描述數(shù)據(jù)庫(kù)中所有的用戶可以訪問的對(duì)象以及相關(guān)的表。
DBA_TAB_COLUMNS:描述數(shù)據(jù)庫(kù)中所有表的列屬性。
USER_TAB_COLUMNS:描述數(shù)據(jù)庫(kù)中當(dāng)前用戶擁有的表的列屬性。
ALL_TAB_COLUMNS:描述數(shù)據(jù)庫(kù)中所有用戶可以訪問的表的列屬性。
DBA_CONSTRAINTS:描述數(shù)據(jù)庫(kù)中所有表的約束和屬性。
DBA_CONS_COLUMNS:包含在DBA_CONSTRAINTS約束定義中的可訪問的列的信息。
ALL_CONSTRAINTS:描述數(shù)據(jù)庫(kù)中所有用戶可以訪問的表的約束和屬性。
ALL_CONS_COLUMNS:包含在ALL_CONSTRAINTS約束定義的可訪問的列的信息。
USER_CONSTRAINTS:描述數(shù)據(jù)庫(kù)中所有當(dāng)前用戶擁有的表的約束的屬性。
USER_CONS_COLUMNS:包含在USER_CONSTRAINTS約束定義的可訪問的列的信息。
DBA_SEQUENCES:數(shù)據(jù)庫(kù)中所有序列的描述。
ALL_SEQUENCES:描述數(shù)據(jù)庫(kù)中所有用戶可以訪問的序列的描述。
USER_SEQUENCES:描述數(shù)據(jù)庫(kù)中所有當(dāng)前用戶擁有的序列的描述。
DBA_INDEXES:描述數(shù)據(jù)庫(kù)中所有的索引的屬性。
ALL_INDEXES:描述數(shù)據(jù)庫(kù)中所有用戶可以訪問的索引的屬性。
USER_INDEXES:描述數(shù)據(jù)庫(kù)中所有當(dāng)前用戶擁有的索引的屬性。
1、Oracle數(shù)據(jù)庫(kù):
select? *? from ‘?dāng)?shù)據(jù)庫(kù)的名字’? where Table_Name='你要查詢表的名字';
2、mysql查詢表所有列名,并用逗號(hào)分隔:
SELECT GROUP_CONCAT(COLUMN_NAME SEPARATOR ",")
FROM information_schema.COLUMNS
WHERE TABLE_SCHEMA = '數(shù)據(jù)庫(kù)的名字' AND TABLE_NAME = '你要查詢表的名字'
擴(kuò)展資料:
Oracle數(shù)據(jù)庫(kù)其他查詢語句:
1、查詢所有表名:
select t.table_name from‘?dāng)?shù)據(jù)庫(kù)的名字’;
2、查詢所有字段名:
select t.column_name from ‘?dāng)?shù)據(jù)庫(kù)的名字’;
3、查詢指定表的所有字段名:
select t.column_name from ‘?dāng)?shù)據(jù)庫(kù)的名字’ where t.table_name = '你要查詢表的名字';
4、查詢指定表的所有字段名和字段說明:
select t.column_name, t.column_name from‘?dāng)?shù)據(jù)庫(kù)的名字’where t.table_name = '你要查詢表的名字';
SELECT
*
FROM
DBA_TAB_COLUMNS
WHERE
TABLE_NAME
=
'USERSCORE'
表名要大寫
desc
userscore;理論上是不應(yīng)該報(bào)錯(cuò)的,是不是你沒寫分號(hào)什么的,或者你把錯(cuò)誤代碼帖一下
在Oracle中,可以使用instr函數(shù)對(duì)某個(gè)字符串進(jìn)行判斷,判斷其是否含有指定的字符。其語法為:
eg: dbms_lob.instr(字段名(clod類型),'查詢條件',1,1)
其中sourceString代表想要查詢的字段;
destString代表查詢條件;
start代表查找的開始位置,該參數(shù)可選的,默認(rèn)為1;
appearPosition代表想從源字符中查找出第幾次出現(xiàn)的destString,該參數(shù)也是可選的,默認(rèn)為1;
如果start的值為負(fù)數(shù),那么代表從右往左進(jìn)行查找。
返回值為:當(dāng)目標(biāo)字符串沒有在源字符串中找到,返回0;當(dāng)源字符串或目標(biāo)字符串為null,則返回null;
其他情況則返回目標(biāo)字符串在源字符串中的其實(shí)位置
SELECT * FROM DBA_TAB_COLUMNS WHERE TABLE_NAME = 'USERSCORE'
表名要大寫
desc userscore;理論上是不應(yīng)該報(bào)錯(cuò)的,是不是你沒寫分號(hào)什么的,或者你把錯(cuò)誤代碼帖一下