成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle Where子句研究結論

數據庫 Oracle
這里介紹Oracle Where子句,包括用Oracle Where子句替代ORDER BY,某些SELECT 語句中的Oracle Where子句不使用索引。

在向大家詳細介紹Oracle Where子句之前,首先讓大家了解下ORDER BY子句,然后全面介紹用Oracle Where子句替代ORDER BY:
◆ORDER BY 子句只在兩種嚴格的條件下使用索引。
◆ORDER BY中任何的列必須包含在相同的索引中并保持在索引中的排列順序。
◆ORDER BY中任何的列必須定義為非空。

Oracle Where子句使用的索引和ORDER BY子句中所使用的索引不能并列。例如: 表DEPT包含以下列:

  1. DEPT_CODE PK NOT NULL  
  2. DEPT_DESC NOT NULL  
  3. DEPT_TYPE NULL 

避免改變索引列的類型:

當比較不同數據類型的數據時, Oracle自動對列進行簡單的類型轉換。 假設 EMPNO是個數值類型的索引列:SELECT … FROM EMP WHERE EMPNO = ‘123'。 實際上,經過Oracle類型轉換, 語句轉化為: SELECT … FROM EMP WHERE EMPNO = TO_NUMBER(‘123') 。

幸運的是,類型轉換沒有發生在索引列上,索引的用途沒有被改變。現在,假設EMP_TYPE是個字符類型的索引列:SELECT … FROM EMP WHERE EMP_TYPE = 123 。

這個語句被Oracle轉換為: SELECT … FROM EMP WHERETO_NUMBER(EMP_TYPE)=123。因為內部發生的類型轉換,這個索引將不會被用到! 為了避免Oracle對您的SQL進行隱式的類型轉換,***把類型轉換用顯式表現出來。注意當字符和數值比較時,Oracle會優先轉換數值類型到字符類型。

需要當心的Oracle Where子句:

某些SELECT 語句中的Oracle Where子句不使用索引。這里有一些例子:
(1)‘!=' 將不使用索引。記住, 索引只能告訴您什么存在于表中, 而不能告訴您什么不存在于表中。
(2)‘||'是字符連接函數。就象其他函數那樣, 停用了索引。
(3)‘ '是數學函數。就象其他數學函數那樣, 停用了索引。
(4)相同的索引列不能互相比較,這將會啟用全表掃描。
a. 假如檢索數據量超過30%的表中記錄數,使用索引將沒有顯著的效率提高。
b. 在特定情況下,使用索引也許會比全表掃描慢,但這是同一個數量級上的區別。而通常情況下,使用索引比全表掃描要塊幾倍乃至幾千倍!

避免使用耗費資源的操作:

帶有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL語句會啟動SQL引擎執行耗費資源的排序(SORT)功能。DISTINCT需要一次排序操作,而其他的至少需要執行兩次排序。通常,帶有 UNION, MINUS , INTERSECT的SQL語句都能夠用其他方式重寫。假如您的數據庫的SORT_AREA_SIZE調配得好。使用UNION , MINUS, INTERSECT也是能夠考慮的, 畢竟他們的可讀性很強。

【編輯推薦】

  1. 詳談Oracle LogMiner工具
  2. 揭開Oracle LogMiner之謎
  3. 簡單描述Oracle Clob類型
  4. 概述Oracle 10g服務器
  5. 簡介Oracle xmltype
責任編輯:佚名 來源: 計世網
相關推薦

2009-09-10 17:30:15

LINQ Where子

2010-09-26 14:46:19

SQL WHERE子句

2010-09-26 09:50:36

SQL Where子句

2009-11-19 13:44:29

Oracle FROM

2011-06-08 15:08:38

MySQLWhere優化

2009-11-19 14:12:16

Oracle Havi

2010-04-02 09:55:47

Oracle遞歸查詢

2024-02-27 09:12:24

PostgreSQL數據庫查詢WHERE 子句

2010-04-02 15:04:14

Oracle遞歸查詢

2011-07-29 15:31:52

Oracle數據庫ORDER BY

2010-11-18 17:24:27

Oracle旋轉ins

2024-10-05 00:00:10

SQL語句指定連接條

2010-04-19 14:23:34

Oracle增加表分區

2011-03-25 09:54:39

Oracle數據庫Where條件

2009-05-21 09:09:47

where查詢條件邏輯值

2011-03-15 14:17:28

Oracle自主訪問

2010-04-12 16:24:15

Oracle表查詢

2010-04-29 16:15:06

Oracle flas

2009-09-16 11:19:48

Linq Select

2009-09-16 13:02:12

LINQ查詢子句
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久高清国产视频 | 欧美一级黄| 免费观看一级毛片 | 一区二区三区中文字幕 | 欧美中文字幕在线观看 | 久热电影 | 欧美日韩亚洲三区 | 亚洲精品一区二区三区蜜桃久 | a在线v| 成年无码av片在线 | 综合在线视频 | 欧美激情在线精品一区二区三区 | 婷婷色国产偷v国产偷v小说 | 在线看免费| 国产精品久久久久一区二区三区 | 黄色欧美视频 | 亚洲精品国产综合区久久久久久久 | 国产一区二区在线免费观看 | 亚洲一区二区免费 | 久久精品成人 | 亚洲精品在线免费观看视频 | 女同久久另类99精品国产 | 91精品国产一区二区三区动漫 | 国产小网站 | 久久大| 久久久久亚洲av毛片大全 | 日韩精品视频一区二区三区 | 亚洲精品永久免费 | 国产亚洲精品久久情网 | 亚洲精品一区二三区不卡 | 久久男人| 国产视频福利一区 | 亚洲一区二区在线免费观看 | 男女视频在线观看 | 精品九九久久 | 一区二区在线 | 国产精品高潮呻吟久久aⅴ码 | 久久久久久久久久久久91 | 性高朝久久久久久久3小时 av一区二区三区四区 | 国产成人99久久亚洲综合精品 | 综合久久综合久久 |