<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 黑豆熊 閱讀(9663) 評論(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无码网站在线观看| 亚洲午夜一区二区三区| 69式国产真人免费视频| 亚洲国产精品综合久久2007| 4虎永免费最新永久免费地址| 亚洲国产av美女网站| 99精品全国免费观看视频| 亚洲AV无码专区在线观看成人 | 亚洲AV无码AV日韩AV网站| 女人被男人躁的女爽免费视频| 亚洲日本VA午夜在线电影| 天天摸天天碰成人免费视频| 看一级毛片免费观看视频| 亚洲人成影院在线观看| 中文字幕在线成人免费看| 亚洲国产香蕉碰碰人人| 在线看片无码永久免费视频| 亚洲av无码一区二区三区天堂| 国产无遮挡又黄又爽免费视频| aa午夜免费剧场| 久久精品国产亚洲香蕉| 国产在线观看麻豆91精品免费| 亚洲精品无AMM毛片| 亚洲国产高清在线一区二区三区| 一二三四在线观看免费中文在线观看| 亚洲国产精品13p| 一级毛片在线免费看| 亚洲欧洲专线一区| 国产午夜亚洲不卡| xxxxwww免费| 高h视频在线免费观看| 亚洲AV区无码字幕中文色| 亚洲va中文字幕无码久久| 99re在线精品视频免费| 亚洲GV天堂无码男同在线观看| 国内精品久久久久久久亚洲| 51在线视频免费观看视频| 另类小说亚洲色图|