成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

SQL如何優(yōu)化

這篇文章主要介紹SQL如何優(yōu)化,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

在康縣等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站制作、成都網(wǎng)站制作 網(wǎng)站設(shè)計制作按需定制開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),網(wǎng)絡(luò)營銷推廣,外貿(mào)網(wǎng)站制作,康縣網(wǎng)站建設(shè)費用合理。

一、存在問題

經(jīng)過sql慢查詢的優(yōu)化,我們系統(tǒng)中發(fā)現(xiàn)了以下幾種類型的問題:

1.未建索引:整張表沒有建索引;2.索引未命中:有索引,但是部分查詢條件下索引未命中;3.搜索了額外的非必要字段,導致回表;4.排序,聚合導致慢查詢;5.相同內(nèi)容多次查詢數(shù)據(jù)庫;6.未消限制搜索范圍或者限制的搜索范圍在預期之外,導致全部掃描;

二、解決方案

1.優(yōu)化索引,增加或者修改當前的索引;         

2.重寫sql;3.利用redis緩存,減少查詢次數(shù);4.增加條件,避免非必要查詢;5.增加條件,減少查詢范圍;

三、案例分析

(一)藥材搜索接口

完整sql語句在附錄,為方便閱讀和脫敏,部分常用字段采用中文。

這兒主要講一下我們拿到Sql語句后的整個分析過程,思考邏輯,然后進行調(diào)整的過程和最后解決的辦法。

給大家提供一些借鑒,也希望大家能夠提出更好的建議。

SQL如何優(yōu)化

這個sql語句要求是根據(jù)醫(yī)生搜索的拼音或者中文,進行模糊查詢,找到藥材,然后根據(jù)醫(yī)生選擇的藥庫,查找下面的供應商,然后根據(jù)供應商,進行藥材匹配,排除掉供應商沒有的藥材,然后根據(jù)真名在前,別名在后,完全匹配在前,部分匹配在后,附加醫(yī)生最近半年的使用習慣,把藥材排序出來。最后把不同名稱的同一味藥聚合起來,以真名(另名)的形式展現(xiàn)。

1.分析sql

  • (1)14-8

第14排,id為8的explain結(jié)果分析:

①Explain
8,DERIVED,ssof,range,"ix_district,ix_供應商id",ix_district,8,NULL,18,Using where; Using index; Using temporary
②Sql
SELECT DISTINCT (ssof.供應商id) AS 供應商id FROM  藥庫供應商關(guān)系表 AS ssof  WHERE ssof.藥庫id IN (  1, 2, 8, 9, 10, 11, 12, 13, 14, 15, 17, 22, 24, 25, 26, 27, 31, 33)  AND ssof.藥方劑型id IN (1)
③索引
PRIMARY KEY (`id`),    UNIQUE KEY `ix_district` (        `藥庫id`, `藥方劑型id`, `供應商id`    ) USING BTREE,KEY `ix_供應商id` (`供應商id`) USING BTREE
④分析

使用了索引,建立了臨時表,這個地方索引已經(jīng)完全覆蓋了,但是還有回表操作。

原因是用in,這個導致了回表。如果in可以被MySQL 自動優(yōu)化為等于,就不會回表。如果無法優(yōu)化,就回表。

臨時表是因為有distinct,所以無法避免。

同時使用in需要注意,如果里面的值數(shù)量比較多,有幾萬個。即使區(qū)分度高,就會導致索引失效,這種情況需要多次分批查詢。

2. 12-7

  • (1)Explain

7,DERIVED,<derived8>,ALL,NULL,NULL,NULL,NULL,18,Using temporary; Using filesort
  • (2)Sql

INNER JOIN (上面14-8臨時表) tp ON tp.供應商id= ms.供應商id
  • (3)索引

  • (4)分析

對臨時表操作,無索引,用了文件排序。

這一部分是對臨時表和藥材表進行關(guān)聯(lián)操作的一部分,有文件排序是因為需要對藥材表id進行g(shù)roup by 導致的。

1、默認情況下,mysql在使用group by之后,會產(chǎn)生臨時表,而后進行排序(此處排序默認是快排),這會消耗的性能。

2、group by本質(zhì)是先分組后排序【而不是先排序后分組】。

3、group by column 默認會按照column分組, 然后根據(jù)column升序排列;  group by column order by null 則默認按照column分組,然后根據(jù)標的主鍵ID升序排列。

3. 13-7

  • (1)Explain

7,DERIVED,ms,ref,"ix_title,idx_audit,idx_mutiy",idx_mutiy,5,"tp.供應商id,const",172,NULL
  • (2)Sql

SELECT ms.藥材表id, max(ms.audit) AS audit, max(ms.price) AS price, max(ms.market_price) AS market_price,max(ms.is_granule) AS is_granule,max(ms.is_decoct) AS is_decoct, max(ms.is_slice) AS is_slice,max(ms.is_cream) AS is_cream, max(ms.is_extract) AS is_extract,max(ms.is_cream_granule) AS is_cream_granule, max(ms.is_extract_granule) AS is_extract_granule,max(ms.is_drychip) AS is_drychip,            max(ms.is_pill) AS is_pill,max(ms.is_powder) AS is_powder, max(ms.is_bolus) AS is_bolus FROM 供應商藥材表 AS ms INNER JOIN (                SELECT                    DISTINCT (ssof.供應商id) AS 供應商id                FROM                    藥庫供應商關(guān)系表 AS ssof WHERE  ssof.藥庫id IN (  1, 2, 8, 9, 10, 11, 12, 13, 14, 15, 17, 22, 24, 25, 26, 27, 31, 33 ) AND ssof.藥方劑型id IN (1) ) tp ON tp.供應商id= ms.供應商id WHERE  ms.audit = 1  GROUP BY  ms.藥材表id
  • (3)索引

   KEY `idx_mutiy` (`供應商id`, `audit`, `藥材表id`)
  • (4)分析

命中了索引,表間連接使用了供應商id,建立索引的順序是供應商id,where條件中audit,Group by 條件藥材表id。

這部分暫時不需要更改。

4.10-6

  • (1)Explain

6,DERIVED,r,range,"PRIMARY,id,idx_timeline,idx_did_timeline,idx_did_isdel_statuspay_timecreate_payorderid,idx_did_statuspay_ischecked_isdel",idx_did_timeline,8,NULL,546,Using where; Using index; Using temporary; Using filesort
  • (2)Sql

SELECT 
       count(*) AS total, 
       rc.i AS m藥材表id 
     FROM 
        處方藥材表 AS rc 
        INNER JOIN 藥方表AS r ON r.id = rc.藥方表_id 
     WHERE 
         r.did = 40 
         AND r.timeline > 1576115196 
         AND rc.type_id in (1, 3) 
         GROUP BY 
    rc.i
  • (3)索引

KEY `idx_did_timeline` (`did`, `timeline`),
  • (4)分析

驅(qū)動表與被驅(qū)動表,小表驅(qū)動大表。

先了解在join連接時哪個表是驅(qū)動表,哪個表是被驅(qū)動表:

1.當使用left join時,左表是驅(qū)動表,右表是被驅(qū)動表;

2.當使用right join時,右表時驅(qū)動表,左表是驅(qū)動表;

3.當使用join時,mysql會選擇數(shù)據(jù)量比較小的表作為驅(qū)動表,大表作為被驅(qū)動表;

4. in后面跟的是驅(qū)動表, exists前面的是驅(qū)動表;

5. 11-6

  • (1)Explain

6,DERIVED,rc,ref,"orderid_藥材表,藥方表_id",藥方表_id,5,r.id,3,Using where
  • (2)Sql

同上

  • (3)索引

  KEY `idx_藥方表_id` (`藥方表_id`, `type_id`) USING BTREE,
  • (4)分析

索引的順序沒有問題,仍舊是in 導致了回表。

6.8-5

  • (1)Explain

5,UNION,malias,ALL,id_tid,NULL,NULL,NULL,4978,Using where
  • (2)Sql

 SELECT 
      mb.id, 
      mb.sort_id, 
      mb.title, 
      mb.py, 
      mb.unit, 
      mb.weight, 
      mb.tid, 
      mb.amount_max, 
      mb.poisonous, 
      mb.is_auxiliary, 
      mb.is_auxiliary_free, 
      mb.is_difficult_powder, 
      mb.brief, 
      mb.is_fixed_recipe, 
      ASE WHEN malias.py = 'GC' THEN malias.title ELSE CASE WHEN malias.title = 'GC' THEN malias.title ELSE '' END END AS atitle, 
      alias.py AS apy, 
      CASE WHEN malias.py = 'GC' THEN 2 ELSE CASE WHEN malias.title = 'GC' THEN 2 ELSE 1 END END AS ttid 
 FROM 
      藥材表 AS mb 
      LEFT JOIN 藥材表 AS malias ON malias.tid = mb.id 
WHERE 
      alias.title LIKE '%GC%' 
      OR malias.py LIKE '%GC%'
  • (3)索引

KEY `id_tid` (`tid`) USING BTREE,
  • (4)分析

因為like是左右like,無法建立索引,所以只能建tid。Type是all,遍歷全表以找到匹配的行,左右表大小一樣,估算的找到所需的記錄所需要讀取的行數(shù)有4978。這個因為是like的緣故,無法優(yōu)化,這個語句并沒有走索引,藥材表 AS mb FORCE INDEX (id_tid) 改為強制索引,讀取的行數(shù)減少了700行。

7.9-5

  • (1)Explain

5,UNION,mb,eq_ref,"PRIMARY,ix_id",PRIMARY,4,malias.tid,1,NULL
  • (2)Sql

同上

  • (3)索引

PRIMARY KEY (`id`) USING BTREE,
  • (4)分析

走了主鍵索引,行數(shù)也少,通過。

8.7-4

  • (1)Explain

4,DERIVED,mb,ALL,id_tid,NULL,NULL,NULL,4978,Using where
  • (2)Sql

    SELECT 
       mb.id, 
       mb.sort_id, 
       mb.title, 
       mb.py, 
       mb.unit, 
       mb.weight, 
       mb.tid, 
       mb.amount_max, 
       mb.poisonous, 
       mb.is_auxiliary, 
       mb.is_auxiliary_free, 
       mb.is_difficult_powder, 
       mb.brief, 
       mb.is_fixed_recipe, 
       '' AS atitle, 
       '' AS apy, 
       CASE WHEN mb.py = 'GC' THEN 3 ELSE CASE WHEN mb.title = 'GC' THEN 3 ELSE 1 END END AS ttid 
    FROM 
       藥材表 AS mb 
      WHERE 
       mb.tid = 0 
       AND (
           mb.title LIKE '%GC%' 
           OR mb.py LIKE '%GC%'
                                )
  • (3)索引

KEY `id_tid` (`tid`) USING BTREE,
  • (4)分析

    tid int(11) NOT NULL DEFAULT ‘0’ COMMENT ‘真名藥品的id’,

他也是like,這個沒法優(yōu)化。

9.6-3

  • (1)Explain

3,DERIVED,<derived4>,ALL,NULL,NULL,NULL,NULL,9154,Using filesort
  • (2)Sql

    UNION ALL

  • (3)索引

  • (4)分析

就是把真名搜索結(jié)果和別人搜索結(jié)果合并。避免用or連接,加快速度 形成一個munion的表,初步完成藥材搜索,接下去就是排序。

這一個進行了2次查詢,然后用union連接,可以考慮合并為一次查詢。用case when進行區(qū)分,計算出權(quán)重。

這邊是一個優(yōu)化點。

10.4-2

  • (1)Explain

2,DERIVED,<derived3>,ALL,NULL,NULL,NULL,NULL,9154,NULL
  • (2)Sql

    SELECT 
       munion.id, 
       munion.sort_id, 
       case when length(
         trim(
              group_concat(munion.atitle SEPARATOR ' ')
                        )
                    )> 0 then concat(
                        munion.title, 
                        '(', 
                        trim(
                            group_concat(munion.atitle SEPARATOR ' ')
                        ), 
                        ')'
                    ) else munion.title end as title, 
          munion.py, 
          munion.unit, 
          munion.weight, 
          munion.tid, 
          munion.amount_max, 
          munion.poisonous, 
          munion.is_auxiliary, 
          munion.is_auxiliary_free, 
          munion.is_difficult_powder, 
          munion.brief, 
          munion.is_fixed_recipe, 
          --  trim( group_concat( munion.atitle SEPARATOR ' ' ) ) AS atitle,
                    ##  --  
           trim(
                 group_concat(munion.apy SEPARATOR ' ')
                 ) AS apy, 
             ##   
               max(ttid) * 100000 + id AS ttid 
         FROM 
                munion <derived4>
             GROUP BY 
                id -- 全部實名藥材 結(jié)束##
  • (3)索引

  • (4)分析

這里全部在臨時表中搜索了。

11.5-2

  • (1)Explain

2,DERIVED,<derived6>,ref,<auto_key0>,<auto_key0>,5,m.id,10,NULL
  • (2)Sql

Select fields from 全部實名藥材表 as m  LEFT JOIN ( 個人使用藥材統(tǒng)計表 ) p ON m.id = p.m藥材表id
  • (3)索引

  • (4)分析

2張?zhí)摂M表left join

使用了優(yōu)化器為派生表生成的索引

這邊比較浪費性能,每次查詢,都要對醫(yī)生歷史開方記錄進行統(tǒng)計,并且統(tǒng)計還是幾張大表計算后的結(jié)果。但是如果只是sql優(yōu)化,這邊暫時無法優(yōu)化。

12.2-1

  • (1)Explain

1,PRIMARY,<derived7>,ALL,NULL,NULL,NULL,NULL,3096,Using where; Using temporary; Using filesort
  • (2)Sql

  • (3)索引

  • (4)分析

臨時表操作

13.3-1

  • (1)Explain

1,PRIMARY,<derived2>,ref,<auto_key0>,<auto_key0>,4,msu.藥材表id,29,NULL
  • (2)Sql

  • (3)索引

  • (4)分析

臨時表操作

14.null

  • (1)Explain

NULL,UNION RESULT,"<union4,5>",ALL,NULL,NULL,NULL,NULL,NULL,Using temporary
  • (2)Sql

  • (3)索引

  • (4)分析

臨時表

(二)優(yōu)化sql

上面我們只做索引的優(yōu)化,遵循的原則是:

1.最左前綴匹配原則,非常重要的原則,mysql會一直向右匹配直到遇到范圍查詢(>、<、between、like)就停止匹配,比如a = 1 and b = 2 and c > 3 and d = 4 如果建立(a,b,c,d)順序的索引,d是用不到索引的,如果建立(a,b,d,c)的索引則都可以用到,a,b,d的順序可以任意調(diào)整。2.=和in可以亂序,比如a = 1 and b = 2 and c = 3 建立(a,b,c)索引可以任意順序,mysql的查詢優(yōu)化器會幫你優(yōu)化成索引可以識別的形式。3.盡量選擇區(qū)分度高的列作為索引,區(qū)分度的公式是count(distinct col)/count(*),表示字段不重復的比例,比例越大我們掃描的記錄數(shù)越少,唯一鍵的區(qū)分度是1,而一些狀態(tài)、性別字段可能在大數(shù)據(jù)面前區(qū)分度就是0,那可能有人會問,這個比例有什么經(jīng)驗值嗎?使用場景不同,這個值也很難確定,一般需要join的字段我們都要求是0.1以上,即平均1條掃描10條記錄。4.索引列不能參與計算,保持列“干凈”,比如from_unixtime(create_time) = ’2014-05-29’就不能使用到索引,原因很簡單,b+樹中存的都是數(shù)據(jù)表中的字段值,但進行檢索時,需要把所有元素都應用函數(shù)才能比較,顯然成本太大。所以語句應該寫成create_time = unix_timestamp(’2014-05-29’)。5.盡量的擴展索引,不要新建索引。比如表中已經(jīng)有a的索引,現(xiàn)在要加(a,b)的索引,那么只需要修改原來的索引即可。

查詢優(yōu)化神器 - explain命令

關(guān)于explain命令相信大家并不陌生,具體用法和字段含義可以參考官網(wǎng)explain-output,這里需要強調(diào)rows是核心指標,絕大部分rows小的語句執(zhí)行一定很快(有例外,下面會講到)。所以優(yōu)化語句基本上都是在優(yōu)化rows。

化基本步驟:

0.先運行看看是否真的很慢,注意設(shè)置SQL_NO_CACHE1.where條件單表查,鎖定最小返回記錄表。這句話的意思是把查詢語句的where都應用到表中返回的記錄數(shù)最小的表開始查起,單表每個字段分別查詢,看哪個字段的區(qū)分度最高;2.explain查看執(zhí)行計劃,是否與1預期一致(從鎖定記錄較少的表開始查詢);3.order by limit 形式的sql語句讓排序的表優(yōu)先查;4.了解業(yè)務(wù)方使用場景;5.加索引時參照建索引的幾大原則;6.觀察結(jié)果,不符合預期繼續(xù)從0分析;

上面已經(jīng)詳細的分析了每一個步驟,根據(jù)上面的sql,去除union操作, 增加索引??梢钥闯觯瑑?yōu)化后雖然有所改善。但是距離我們的希望還有很大距離,但是光做sql優(yōu)化,感覺也沒有多少改進空間,所以決定從其他方面解決。

(三)拆分sql

由于速度還是不領(lǐng)人滿意,尤其是個人用藥情況統(tǒng)計,其實沒必要每次都全部統(tǒng)計一次,再要優(yōu)化,只靠修改索引應該是不行的了,所以考慮使用緩存。

接下來是修改php代碼,把全部sql語句拆分,然后再組裝。

  • (1)搜索真名,別名(緩存)

SELECT  mb.id,  mb.sort_id,  mb.title,  mb.py,  mb.unit,  mb.weight,  mb.tid,  mb.amount_max,  mb.poisonous,  mb.is_auxiliary,  mb.is_auxiliary_free,  mb.is_difficult_powder,  mb.brief,  mb.is_fixed_recipe,  IFNULL(group_concat(malias.title),'') atitle,  IFNULL(group_concat(malias.py),'') apy  FROM  藥材表 AS mb  LEFT JOIN 藥材表 AS malias ON malias.tid = mb.id  WHERE  mb.tid = 0  AND (  malias.title LIKE '%GC%'  OR malias.py LIKE '%GC%'  or mb.title LIKE '%GC%'  OR mb.py LIKE '%GC%'  )  group by  mb.id

SQL如何優(yōu)化

  • (2)如果命中有藥材

①排序

真名在前,別名在后,完全匹配在前,部分匹配在后

//對搜索結(jié)果進行處理,增加權(quán)重
②對供應商藥材搜索
SELECT ms.藥材表id, max( ms.audit ) AS audit, max( ms.price ) AS price, max( ms.market_price ) AS market_price, max( ms.is_granule ) AS is_granule, max( ms.is_decoct ) AS is_decoct, max( ms.is_slice ) AS is_slice, max( ms.is_cream ) AS is_cream, max( ms.is_extract ) AS is_extract, max( ms.is_cream_granule) AS is_cream_granule, max( ms.is_extract_granule) AS is_extract_granule, max( ms.is_drychip ) AS is_drychip, max( ms.is_pill ) AS is_pill, max( ms.is_powder ) AS is_powder, max( ms.is_bolus ) AS is_bolus  FROM 供應商藥材表 AS ms WHERE ms.audit = 1 AND ms.供應商idin (  SELECT DISTINCT  ( ssof.供應商id) AS 供應商id FROM  藥庫供應商關(guān)系表 AS ssof  WHERE  ssof.藥庫id IN ( 1,2,8,9,10,11,12,13,14,15,17,22,24,25,26,27,31,33 )  AND ssof.藥方劑型id IN (1) ) AND ms.藥材表id IN ( 78,205,206,207,208,209,334,356,397,416,584,652,988,3001,3200,3248,3521,3522,3599,3610,3624,4395,4396,4397,4398,4399,4400,4401,4402,4403,4404,4405,4406,4407,4408,5704,5705,5706,5739,5740,5741,5742,5743,6265,6266,6267,6268,6514,6515,6516,6517,6518,6742,6743 ) AND ms.is_slice = 1  GROUP BY ms.藥材表id

SQL如何優(yōu)化

③拿醫(yī)生歷史開方藥材用量數(shù)據(jù)(緩存)
SELECT  count( * ) AS total,  rc.i AS 藥材表id FROM  處方藥材表 AS rc  INNER JOIN 藥方表AS r ON r.id = rc.藥方表_id WHERE  r.did = 40  AND r.timeline > 1576116927  AND rc.type_id in (1,3) GROUP BY  rc.i

SQL如何優(yōu)化

④  裝配及排序微調(diào)

SQL如何優(yōu)化

SQL如何優(yōu)化

SQL如何優(yōu)化

  • (3)小結(jié)

運行速度,對于開方量不是特別多的醫(yī)生來說,兩者速度都是0.1秒左右.但是如果碰到開方量大的醫(yī)生,優(yōu)化后的sql速度比較穩(wěn)定,能始終維持在0.1秒左右,優(yōu)化前的sql速度會超過0.2秒.速度提升約一倍以上。

最后對搜索結(jié)果和未優(yōu)化前的搜索結(jié)果進行比對,結(jié)果數(shù)量和順序完全一致.本次優(yōu)化結(jié)束。

四、附錄:

SELECT sql_no_cache 
    *FROM
    (
        -- mbu start##        SELECT
            m.*,
            ifnull(p.total, 0) AS total        FROM
            (
                --全部實名藥材
開始
##SELECT
       munion.id,
       munion.sort_id,
       case when length(
        trim(
              group_concat(munion.atitle SEPARATOR ' ')
                 )
             )> 0 then concat(
           munion.title,
          '(',
      trim(
             group_concat(munion.atitle SEPARATOR ' ')
              ),
                ')'
             ) else munion.title end as title,
        munion.py,
        munion.unit,
        munion.weight,
        munion.tid,
        munion.amount_max,
        munion.poisonous,
        munion.is_auxiliary,
        munion.is_auxiliary_free,
        munion.is_difficult_powder,
        munion.brief,
        munion.is_fixed_recipe,
        --  trim( group_concat( munion.atitle SEPARATOR ' ' ) ) AS atitle,##        --  trim( group_concat( munion.apy SEPARATOR  ' ' ) ) AS apy,##              max(ttid) * 100000 + id AS ttid           FROM
              (
                -- #union start
聯(lián)合查找,得到全部藥材
##  (
       SELECT
              mb.id,
              mb.sort_id,
              mb.title,
              mb.py,
              mb.unit,
              mb.weight,
              mb.tid,
              mb.amount_max,
              mb.poisonous,
              mb.is_auxiliary,
              mb.is_auxiliary_free,
              mb.is_difficult_powder,
              mb.brief,
              mb.is_fixed_recipe,
              '' AS atitle,
              '' AS apy,
              CASE WHEN mb.py = 'GC' THEN 3 ELSE CASE WHEN mb.title = 'GC' THEN 3 ELSE 1 END END AS ttid               FROM
                 藥材表 AS mb                     WHERE
                         mb.tid = 0
                       AND (
                              mb.title LIKE '%GC%'
                              OR mb.py LIKE '%GC%'
                                )
                        ) --真名藥材

結(jié)束
## UNION ALL
    (
      SELECT
            mb.id,
            mb.sort_id,
            mb.title,
            mb.py,
            mb.unit,
            mb.weight,
            mb.tid,
            mb.amount_max,
            mb.poisonous,
            mb.is_auxiliary,
            mb.is_auxiliary_free,
            mb.is_difficult_powder,
            mb.brief,
            mb.is_fixed_recipe,
            CASE WHEN malias.py = 'GC' THEN malias.title ELSE CASE WHEN malias.title = 'GC' THEN malias.title ELSE '' END END AS atitle,
            malias.py AS apy,
            CASE WHEN malias.py = 'GC' THEN 2 ELSE CASE WHEN malias.title = 'GC' THEN 2 ELSE 1 END END AS ttid          FROM
                藥材表 AS mb                LEFT JOIN 藥材表 AS malias ON malias.tid = mb.id          WHERE
                malias.title LIKE '%GC%'
                OR malias.py LIKE '%GC%'
                      ) --其他藥材結(jié)束
##                 -- #union end##                ) munion                GROUP BY
                    id --全部實名藥材

結(jié)束
##                    ) m            LEFT JOIN (
                --個人使用藥材統(tǒng)計

開始
##    SELECT
          count(*) AS total,
          rc.i AS m藥材表id     FROM
           處方藥材表 AS rc           INNER JOIN 藥方表AS r ON r.id = rc.藥方表_id      WHERE
           r.did = 40
            AND r.timeline > 1576115196
            AND rc.type_id in (1, 3)
       GROUP BY
              rc.i --個人使用藥材統(tǒng)計

結(jié)束
##           ) p ON m.id = p.m藥材表id -- mbu end ##            ) mbu    INNER JOIN (
        -- msu start
供應商藥材篩選
##        SELECT
            ms.藥材表id,
            max(ms.audit) AS audit,
            max(ms.price) AS price,
            max(ms.market_price) AS market_price,
            max(ms.is_granule) AS is_granule,
            max(ms.is_decoct) AS is_decoct,
            max(ms.is_slice) AS is_slice,
            max(ms.is_cream) AS is_cream,
            max(ms.is_extract) AS is_extract,
            max(ms.is_cream_granule) AS is_cream_granule,
            max(ms.is_extract_granule) AS is_extract_granule,
            max(ms.is_drychip) AS is_drychip,
            max(ms.is_pill) AS is_pill,
            max(ms.is_powder) AS is_powder,
            max(ms.is_bolus) AS is_bolus        FROM
            供應商藥材表 AS ms            INNER JOIN (
                SELECT
                    DISTINCT (ssof.供應商id) AS 供應商id                FROM
                    藥庫供應商關(guān)系表 AS ssof                WHERE
                    ssof.藥庫id IN (
                        1, 2, 8, 9, 10, 11, 12, 13, 14, 15, 17, 22,
                        24, 25, 26, 27, 31, 33
                    )
                    AND ssof.藥方劑型id IN (1)
            ) tp ON tp.供應商id= ms.供應商id        WHERE
            ms.audit = 1
        GROUP BY
            ms.藥材表id -- msu end ##            ) msu ON mbu.id = msu.藥材表idWHERE
    msu.藥材表id > 0
    AND msu.is_slice = 1order by
    total desc,
    ttid desc

以上是“SQL如何優(yōu)化”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

網(wǎng)頁題目:SQL如何優(yōu)化
路徑分享:http://jinyejixie.com/article8/iiheip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導航網(wǎng)站營銷、外貿(mào)建站、域名注冊、做網(wǎng)站商城網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)