首頁  >  問答  >  主體

Mysql查詢回傳太慢

我已經寫了一個查詢。它效果更好。但目前,所有表都有 100K 行,而且我的一個查詢返回速度太慢。您能否建議我如何優化查詢?

select * 
from tbl_xray_information X 
WHERE locationCode = (SELECT t.id 
                      from tbl_location t 
                      where CODE = '202') 
  AND ( communicate_with_pt is NULL || communicate_with_pt='')
  AND x.patientID NOT IN (SELECT patientID 
                          FROM tbl_gxp_information 
                          WHERE center_id = '202')
order by insertedON desc LIMIT 2000

請注意此處「病人 ID」是 varchar。

P粉727531237P粉727531237185 天前383

全部回覆(1)我來回復

  • P粉124890778

    P粉1248907782024-03-31 00:07:43

    可能運行得更快:

    select  *
        from  tbl_xray_information AS X
        WHERE  locationCode = 
            ( SELECT  t.id
                from  tbl_location t
                where  CODE = '202'
            )
          AND  ( x.communicate_with_pt is NULL 
              OR x.communicate_with_pt = '' )
          AND  NOT EXISTS ( SELECT 1 FROM tbl_gxp_information
                  WHERE x.patientID = patientID
                    AND center_id = '202' )
        order by  insertedON desc
        LIMIT  2000

    這些索引可能有幫助:

    tbl_location:  INDEX(CODE)
    tbl_gxp_information:  INDEX(center_id, patientID)  -- (either order)

    由於 OR 優化不佳,可能最好為 communicate_with_pt 選擇 NULL 或空字串(以避免對兩者進行測試)。

    回覆
    0
  • 取消回覆