<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    黑豆熊——BlogJava

    面對挑戰,我告訴自己:面對是勇氣,積極面對是態度,堅持積極面對是毅力!

    常用鏈接

    統計

    積分與排名

    最新評論

    sql語句的執行順序--簡介

    今天上午在開發的過程中,突然遇到一個問題,需要了解SQL語句的執行順序才能繼續,上網上查了一下相關的資料,現整理如下:
    一、sql語句的執行步驟:
     1)語法分析,分析語句的語法是否符合規范,衡量語句中各表達式的意義。
    2) 語義分析,檢查語句中涉及的所有數據庫對象是否存在,且用戶有相應的權限。
    3)視圖轉換,將涉及視圖的查詢語句轉換為相應的對基表查詢語句。
    4)表達式轉換, 將復雜的 SQL 表達式轉換為較簡單的等效連接表達式。
     5)選擇優化器,不同的優化器一般產生不同的“執行計劃”
    6)選擇連接方式, ORACLE 有三種連接方式,對多表連接 ORACLE 可選擇適當的連接方式。
    7)選擇連接順序, 對多表連接 ORACLE 選擇哪一對表先連接,選擇這兩表中哪個表做為源數據表。
    8)選擇數據的搜索路徑,根據以上條件選擇合適的數據搜索路徑,如是選用全表搜索還是利用索引或是其他的方式。
    9)運行“執行計劃”
    二、oracle 共享原理:
            ORACLE將執行過的SQL語句存放在內存的共享池(shared buffer pool)中,可以被所有的數據庫用戶共享 當你執行一個SQL語句(有時被稱為一個游標)時,如果它和之前的執行過的語句完全相同, ORACLE就能很快獲得已經被解析的語句以及最好的 執行路徑. 這個功能大大地提高了SQL的執行性能并節省了內存的使用
    三、oracle 語句提高查詢效率的方法:1: where column in(select * from ... where ...); 2:... where exists (select 'X' from ...where ...); 第二種格式要遠比第一種格式的效率高。在Oracle中可以幾乎將所有的IN操作符子查詢改寫為使用EXISTS的子查詢 使用EXIST,Oracle系統會首先檢查主查詢,然后運行子查詢直到它找到第一個匹配項,這就節省了時間 Oracle系統在執行IN子查詢時,首先執行子查詢,并將獲得的結果列表存放在在一個加了索引的臨時表中 避免使用having字句 避免使用HAVING子句, HAVING 只會在檢索出所有記錄之后才對結果集進行過濾. 這個處理需要排序,總計等操作. 如果能通過WHERE子句限制記錄的數目,那就能減少這方面的開銷

    SQL Select語句完整的執行順序: 

    1、from子句組裝來自不同數據源的數據;
     2、where子句基于指定的條件對記錄行進行篩選;
    3、group by子句將數據劃分為多個分組;
    4、使用聚集函數進行計算;
    5、使用having子句篩選分組;
    6、計算所有的表達式;
    7、使用order by對結果集進行排序。

    posted on 2008-11-28 11:17 黑豆熊 閱讀(9655) 評論(6)  編輯  收藏

    評論

    # re: sql語句的執行順序--簡介 2008-11-28 13:19 charlie's logic

    thx  回復  更多評論   

    # re: sql語句的執行順序--簡介 2008-11-28 21:37 lyoe

    很不錯~后面的知道,前面的那個“執行步驟”以前還真不知道  回復  更多評論   

    # re: sql語句的執行順序--簡介 2009-03-06 09:11 thirdline

    很好!以前了解一點SQL執行順序,現在全忘了.
    今天看到你的文章,真的就回憶起來了,呵呵,謝謝!
    不知道博主是否同意轉載?  回復  更多評論   

    # re: sql語句的執行順序--簡介 2009-06-04 09:22 thebye85

    select 是在什么時候執行的?  回復  更多評論   

    # re: sql語句的執行順序--簡介[未登錄] 2009-10-04 08:30 test

    @thebye85
    最后執行  回復  更多評論   

    # re: sql語句的執行順序--簡介 2011-09-07 18:32 GavinMiao

    頂,不錯!  回復  更多評論   


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 久久精品国产亚洲AV无码麻豆 | 中文字幕天天躁日日躁狠狠躁免费| www国产亚洲精品久久久日本| 亚洲色欲色欲www在线播放| 无码人妻精品中文字幕免费东京热| 亚洲天堂中文字幕| 小日子的在线观看免费| 亚洲国产精品lv| 免费无码中文字幕A级毛片| 911精品国产亚洲日本美国韩国 | 24小时免费直播在线观看| 亚洲综合精品成人| 免费黄色网址入口| 亚洲av无码一区二区三区天堂| 免费又黄又硬又爽大片| 免费无码午夜福利片| 久久亚洲AV无码西西人体| 国产精品偷伦视频观看免费 | 亚洲人成网站免费播放| 国产无遮挡吃胸膜奶免费看 | 香蕉97碰碰视频免费| 亚洲视频在线免费| 精品视频在线免费观看| 亚洲天堂中文字幕在线观看| 动漫黄网站免费永久在线观看| 亚洲AV无码XXX麻豆艾秋| 337p日本欧洲亚洲大胆裸体艺术 | 亚洲免费在线观看| 久久香蕉国产线看观看亚洲片| 91免费国产自产地址入| 在线精品亚洲一区二区| 无码国产亚洲日韩国精品视频一区二区三区 | 在线电影你懂的亚洲| 在线精品免费视频| 国产黄色免费观看| 一区二区免费国产在线观看 | 久久精品国产亚洲AV无码偷窥| 久久A级毛片免费观看| 亚洲人成77777在线观看网| 日韩精品电影一区亚洲| 日韩免费在线观看视频|