當前位置:首頁 » 編程語言 » 查看索引列表的sql語句
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

查看索引列表的sql語句

發布時間: 2022-08-10 13:36:56

① 如何查詢資料庫或者表中的索引

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資料庫中已經創建的索引

  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 ; --['用戶名']可省,默認為登錄用戶。

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,並進行登錄。