① 如何查詢資料庫或者表中的索引
oracle對於資料庫中的表信息,存儲在系統表中。查詢已創建好的表索引,可通過相應的sql語句到相應的表中進行快捷的查詢:
1.
根據表名,查詢一張表的索引
select
*
from
user_indexes
where
table_name=upper('表名');
2.
根據索引號,查詢表索引欄位
select
*
from
user_ind_columns
where
index_name=('索引名');
3.根據索引名,查詢創建索引的語句
select
dbms_metadata.get_ddl('index','索引名',
['用戶名'])
from
al
;
--['用戶名']可省,默認為登錄用戶
ps:dbms_metadata.get_ddl還可以得到建表語句,如:
select
dbms_metadata.get_ddl('table','表名',
['用戶名'])
from
al
;
//取單個表的建表語句,['用戶名']可不輸入,默認為登錄用戶
select
dbms_metadata.get_ddl('table',u.table_name)
from
user_tables
u;
//取用戶下所有表的建表語句
當然,也可以用pl/sql
developer工具來查看相關的表的各種信息。
② SQL定義索引的語句有哪些
用SQL建立索引
為了給一個表建立索引,啟動任務欄SQL Sever程序組中的ISQL/w程序。進入查詢窗口後,輸入下面的語句:
CREATE INDEX mycolumn_index ON mytable (myclumn)
這個語句建立了一個名為mycolumn_index的索引。你可以給一個索引起任何名字,但你應該在索引名中包含所索引的欄位名,這對你將來弄清楚建立該索引的意圖是有幫助的。
注意:
執行後,都會收到如下的信息:
This command did not return data,and it did not return any rows
這說明該語句執行成功了。
索引mycolumn_index對表mytable的mycolumn欄位進行。這是個非聚簇索引,也是個非唯一索引。(這是一個索引的預設屬性)
如果你需要改變一個索引的類型,你必須刪除原來的索引並重建 一個。建立了一個索引後,你可以用下面的SQL語句刪除它:
DROP INDEX mytable.mycolumn_index
注意在DROP INDEX 語句中你要包含表的名字。在這個例子中,你刪除的索引是mycolumn_index,它是表mytable的索引。
要建立一個聚簇索引,可以使用關鍵字CLUSTERED。記住一個表只能有一個聚簇索引。
這里有一個如何對一個表建立聚簇索引的例子:
CREATE CLUSTERED INDEX mycolumn_clust_index ON mytable(mycolumn)
如果表中有重復的記錄,當你試圖用這個語句建立索引時,會出現錯誤。但是有重復記錄的表也可以建立索引;你只要使用關鍵字ALLOW_DUP_ROW把這一點告訴SQL Sever即可:
CREATE CLUSTERED INDEX mycolumn_cindex ON mytable(mycolumn) WITH ALLOW_DUP_ROW
這個語句建立了一個允許重復記錄的聚簇索引。你應該盡量避免在一個表中出現重復記錄,但是,如果已經出現了,你可以使用這種方法。
要對一個表建立唯一索引,可以使用關鍵字UNIQUE。對聚簇索引和非聚簇索引都可以使用這個關鍵字。這里有一個例子:
CREATE UNIQUE COUSTERED INDEX myclumn_cindex ON mytable(mycolumn)
這是你將經常使用的索引建立語句。無論何時,只要可以,你應該盡量對一個對一個表建立唯一聚簇索引來增強查詢操作。
最後,要建立一個對多個欄位的索引──復合索引──在索引建立語句中同時包含多個欄位名。下面的例子對firstname和lastname兩個欄位建立索引:
CREATE INDEX name_index ON username(firstname,lastname)
這個例子對兩個欄位建立了單個索引。在一個復合索引中,你最多可以對16個欄位進行索引。
用事務管理器建立索引
用事務管理器建立索引比用SQL語句容易的多。使用事務管理器,你可以看到已經建立的索引的列表,並可以通過圖形界面選擇索引選項。
使用事務管理器你可以用兩種方式建立索引:使用Manage Tables窗口或使用Manage Indexes窗口。
要用Manage Tables 窗口建立一個新索引,單擊按鈕Advanced Options(它看起來象一個前面有一加號的表)。這樣就打開了Advanced Options對話框。這個對話框有一部分標名為Primary Key。
要建立一個新索引,從下拉列表中選擇你想對之建立索引的欄位名。如果你想建立一個對多欄位的索引,你可以選擇多個欄位名。你還可以選擇索引是聚簇的還是非聚簇的。在保存表信息後,索引會自動被建立。在Manage Tables窗口中的欄位名旁邊,會出現一把鑰匙。
你已經為你的表建立了「主索引」。主索引必須對不包含空值的欄位建立。另外,主索引強制一個欄位成為唯一值欄位。
要建立沒有這些限制的索引,你需要使用Manage Indexes窗口。從菜單中選擇Manage|Indexes,打開Manage Indexes 窗口。在Manage Indexes 窗口中,你可以通過下拉框選擇表和特定的索引。(見圖11.2)。要建立一個新索引,從Index下拉框中選擇New Index.,然後就可以選擇要對之建立索引的欄位。單擊按鈕Add,把欄位加人到索引中。
你可以為你的索引選擇許多不同的選項。例如,你可以選擇該索引是聚簇的還是非聚簇的。你還可以指定該索引為唯一索引。設計好索引後,單擊按鈕Build,建立該索引。
注意:
唯一索引是指該欄位不能有重復的值,而不是只能建立這一個索引。
③ sql server 怎麼查看錶的索引
SELECT 索引名稱=a.name
,表名=c.name
,索引欄位名=d.name
,索引欄位位置=d.colid
FROM sysindexes a
JOIN sysindexkeys b ON a.id=b.id AND a.indid=b.indid
JOIN sysobjects c ON b.id=c.id
JOIN syscolumns d ON b.id=d.id AND b.colid=d.colid
WHERE a.indid NOT IN(0,255)
-- and c.xtype='U' and c.status>0 --查所有用戶表
AND c.name='message' --查指定表
ORDER BY c.name,a.name,d.name
需創建索引 例如:
根據某列判斷是否有重復記錄,如果該列為非主鍵,則創建索引
根據經常查詢的列,創建索引
無須創建索引
欄位內容大部分一樣,例如:男,女
不要給所有的列都創建索引,這樣在創建新記錄時,增加維護開銷時間。
④ 如何查詢Oracle資料庫中已經創建的索引
根據表名,查詢一張表的索引:
select * from user_indexes where table_name=upper('表名')。根據索引號,查詢表索引欄位:
select * from user_ind_columns where index_name=('索引名')。根據索引名,查詢創建索引的語句:
select dbms_metadata.get_ddl('INDEX','索引名', ['用戶名']) from al ; --['用戶名']可省,默認為登錄用戶。
Oracle資料庫產品為財富排行榜上的前1000家公司所採用,許多大型網站也選用了Oracle系統。
⑤ SQL語句中如何查找索引名是那個表格的
SELECTparent_objFROMsys.sysobjectsWHEREname='PK_xxxxxx'ANDxtype='PK';
--得到parent_objxxx
--方法1
SELECT*FROMsys.sysobjectsWHEREid=xxx;
--方法2
SELECT*FROMsys.tablesWHEREobject_id=xxx;
⑥ 【求助】oracle中sql語句 此列列表已索引的解決辦法
1、在計算機中,打開Oracle的連接程序,用新建的資料庫管理員。
⑦ 如何查詢sqlserver資料庫中得所有索引
select a.name as tabname
,h.name as idname
from sys.objects as a
right join sys.indexes as h on a.object_id=h.object_id
where a.type<>'s'
go
由於索引和系統列沒有直接對應關系 所以不能直接查看列欄位和欄位長度
⑧ 怎麼查看一個sql語句是否使用了索引
1、首先打開PL/SQL,並進行登錄。