1. <var id="fe6gj"></var>

    <rp id="fe6gj"><nav id="fe6gj"></nav></rp>

    <noframes id="fe6gj"><cite id="fe6gj"></cite>

    <ins id="fe6gj"><button id="fe6gj"><p id="fe6gj"></p></button></ins>
    1. <tt id="fe6gj"><i id="fe6gj"><sub id="fe6gj"></sub></i></tt>
        始創于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業
        • 60秒人工響應
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        您的位置: 網站首頁 > 幫助中心>文章內容

        數據庫查詢優化原則

        發布時間:  2012/9/14 17:27:58
          1.對數據庫查詢進行優化,應盡量避免全表掃描,首先應考慮在where 及order by 涉及的列上建立索引。
         
        2.應盡量避免在 where 子句中對字段進行 null 值判斷,否則將導致引擎放棄使用索引而進行全表掃描,如:
         
        select id from t where num is null
         
        可以在num上設置默認值0,確保表中num列沒有null值,然后這樣查詢:
         
        select id from t where num=0
         
        3.應盡量避免在 where 子句中使用!=或<>操作符,否則將引擎放棄使用索引而進行全表掃描。
         
        4.應盡量避免在 where 子句中使用 or 來連接條件,否則將導致引擎放棄使用索引而進行全表掃描,如:
         
        select id from t where num=10 or num=20
         
        可以這樣查詢:
         
        select id from t where num=10
         
        union all
         
        select id from t where num=20

        海洋QQ1359731023
        電話0371-63322216

         
        5. in 和 not in 也要慎用,否則會導致全表掃描,如:
         
        select id from t where num in(1,2,3)
         
        對于連續的數值,能用 between 就不要用 in 了:
         
        select id from t where num between 1 and 3
         
        6.下面的查詢也將導致全表掃描:
         
        select id from t where name like '%abc%'
         
        若要提高效率,可以考慮全文檢索。
         
        7.如果在 where 子句中使用參數,也會導致全表掃描。因為SQL只有在運行時才會解析局部變量,但優化程序不能將訪問計劃的選擇推遲到運行時;它必須在編譯時進行選擇。然而,如果在編譯時建立訪問計劃,變量的值還是未知的,因而無法作為索引選擇的輸入項。如下面語句將進行全表掃描:
         
        select id from t wherenum=@num
         
        可以改為強制查詢使用索引:
         
        select id from t with(index(索引名)) wherenum=@num
         
        8.應盡量避免在 where 子句中對字段進行表達式操作,這將導致引擎放棄使用索引而進行全表掃描。如:
         
        select id from t where num/2=100
         
        應改為:
         
        select id from t where num=100*2
         
        9.應盡量避免在where子句中對字段進行函數操作,這將導致引擎放棄使用索引而進行全表掃描。如:
         
        select id from t where substring(name,1,3)='abc'--name以abc開頭的id
         
        select id from t where datediff(day,createdate,'2005-11-30')=0--‘2005-11-30’生成的id

        海洋QQ1359731023
        電話0371-63322216
        本文出自:億恩科技【www.endtimedelusion.com】

        服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

      1. 您可能在找
      2. 億恩北京公司:
      3. 經營性ICP/ISP證:京B2-20150015
      4. 億恩鄭州公司:
      5. 經營性ICP/ISP/IDC證:豫B1.B2-20060070
      6. 億恩南昌公司:
      7. 經營性ICP/ISP證:贛B2-20080012
      8. 服務器/云主機 24小時售后服務電話:0371-60135900
      9. 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
      10. 專注服務器托管17年
        掃掃關注-微信公眾號
        0371-60135900
        Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
          0
         
         
         
         

        0371-60135900
        7*24小時客服服務熱線

         
         
        av不卡不卡在线观看_最近2018年中文字幕_亚洲欧美一区二区三区_一级A爱做片免费观看国产_日韩在线中文天天更新_伊人中文无码在线