什麼時候需要建索引,什麼時候不需要?

2022-09-09 00:21:18 字數 412 閱讀 5033

什麼時候要索引?

1、表的主鍵、外來鍵必須有索引

2、資料量超過300必須有索引

3、經常與其他表進行連線的表,在連線欄位上建立索引

4、經常出現在where子句的字段,特別是大表字段,必須建索引

5、索引應建立在小字段上,對於大文字字段甚至超長字段,不要建索引

什麼時候不需要索引?

1、建立組合索引,但查詢謂詞並未使用組合索引第一列,此時索引也是無效的

2、在包含有null值的table列上建索引,使用select count(*) from table時不會使用索引

3、在索引列上使用函式不會使用索引,除非新建函式索引

4、被索引的列進行隱式型別轉換時不會使用索引

5、當查詢資料量佔整個錶比重大時,full scan table採用多塊讀查詢更快

什麼時候用exists 什麼時候用in

in not in exists not exists 使用exists,oracle會首先檢查主查詢,然後執行子查詢直到它找到第乙個匹配項,這就節省了時間。oracle在執行in子查詢時,首先執行 子查詢,並將獲得的結果列表存放在乙個加了索引的臨時表中。在執行子查詢之前,系統先將主查詢掛起 待子查...

什麼時候用GET?什麼時候用POST?

get和post兩種方法都是將資料送到伺服器,但你該用哪一種呢?http標準包含這兩種方法是為了達到不同的目的。post用於建立資源,資源的內容會被編入http請示的內容中。例如,處理訂貨表單 在資料庫中加入新資料行等。當請求無 時 如進行搜尋 便可使用get方法 當請求有 時 如新增資料行 則用p...

什麼時候用堆,什麼時候用棧?

參考文章 c 面試題之記憶體分配 一 首先,回顧一下c c 的記憶體分配機制。乙個c c 程式編譯時記憶體分為5大儲存區 堆區 棧區 靜態區 全域性區 文字常量區 儲存字串常量 程式 區 存放二進位制程式 下面主要闡述前面三個。1 靜態儲存區域 靜態儲存區域的 內存在程式編譯時就已經分配好,這塊內存...