激情五月天婷婷,亚洲愉拍一区二区三区,日韩视频一区,a√天堂中文官网8

<ul id="buwfs"><strike id="buwfs"><strong id="buwfs"></strong></strike></ul>
    <output id="buwfs"></output>
  • <dfn id="buwfs"><source id="buwfs"></source></dfn>
      <dfn id="buwfs"><td id="buwfs"></td></dfn>
      <div id="buwfs"><small id="buwfs"></small></div>
      <dfn id="buwfs"><source id="buwfs"></source></dfn>
      1. <dfn id="buwfs"><td id="buwfs"></td></dfn>
        始創(chuàng)于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業(yè)
        • 60秒人工響應
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        全部產(chǎn)品
        您的位置: 網(wǎng)站首頁 > 幫助中心>文章內容

        數(shù)據(jù)庫查詢優(yōu)化原則

        發(fā)布時間:  2012/9/14 17:27:58
          1.對數(shù)據(jù)庫查詢進行優(yōu)化,應盡量避免全表掃描,首先應考慮在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)
         
        對于連續(xù)的數(shù)值,能用 between 就不要用 in 了:
         
        select id from t where num between 1 and 3
         
        6.下面的查詢也將導致全表掃描:
         
        select id from t where name like '%abc%'
         
        若要提高效率,可以考慮全文檢索。
         
        7.如果在 where 子句中使用參數(shù),也會導致全表掃描。因為SQL只有在運行時才會解析局部變量,但優(yōu)化程序不能將訪問計劃的選擇推遲到運行時;它必須在編譯時進行選擇。然而,如果在編譯時建立訪問計劃,變量的值還是未知的,因而無法作為索引選擇的輸入項。如下面語句將進行全表掃描:
         
        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子句中對字段進行函數(shù)操作,這將導致引擎放棄使用索引而進行全表掃描。如:
         
        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
        本文出自:億恩科技【mszdt.com】

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

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

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