欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql 行列轉(zhuǎn)換的示例代碼

 更新時間:2021年03月24日 09:05:03   作者:看,月亮在跳舞  
這篇文章主要介紹了mysql 行列轉(zhuǎn)換的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、需求

我們有三張表,我們需要分類統(tǒng)計一段時間內(nèi)抗生素的不同藥敏結(jié)果,即 report_item_drugs 表的 drugs_result, 在不同項目project_name 和不同抗生素 antibiotic_dict_name 下的占比,并將藥敏結(jié)果顯示在行上,效果如下:

三張原始表(僅取需要的字段示例),分別是:

報告表

項目表

抗生素表(藥敏結(jié)果drugs_result為一列值)

二、實現(xiàn)

1、按照項目、抗生素分組求出檢出的總數(shù)

SELECT 
 A.project_name,A.antibiotic_dict_name,SUM(nums) AS 檢出總數(shù)
FROM 
(
      SELECT i.project_name,d.antibiotic_dict_name,d.drugs_result,COUNT(d.id) AS nums FROM `report` r
       RIGHT JOIN report_item i ON r.id=i.report_id
       RIGHT JOIN report_item_drugs d ON d.report_item_id=i.id
       WHERE r.report_status=2 AND r.add_date BETWEEN '2020-01-01' AND '2020-12-30' 
       GROUP BY i.project_id,d.antibiotic_dict_id,d.drugs_result
 )  A
 GROUP BY A.project_name,A.antibiotic_dict_name

2、按照項目、抗生素、藥敏結(jié)果求出不同藥敏結(jié)果數(shù)量

SELECT i.project_name,d.antibiotic_dict_name,IF(d.drugs_result<>'', d.drugs_result, '未填寫') AS drugs_result,COUNT(d.id) AS 數(shù)量 
FROM `report` r
RIGHT JOIN report_item i ON r.id=i.report_id
RIGHT JOIN report_item_drugs d ON d.report_item_id=i.id
WHERE r.report_status=2 AND r.add_date BETWEEN '2020-01-01' AND '2020-12-30' 
GROUP BY i.project_id,d.antibiotic_dict_id,d.drugs_result  

3、將兩個結(jié)果關(guān)聯(lián)到一起

SELECT 
      BB.project_name,BB.antibiotic_dict_name,BB.drugs_result,BB.`數(shù)量`,AA.`檢出總數(shù)`
    FROM 
        (
              SELECT 
                A.project_name,A.antibiotic_dict_name,SUM(nums) AS 檢出總數(shù)
              FROM 
              (
                    SELECT i.project_name,d.antibiotic_dict_name,d.drugs_result,COUNT(d.id) AS nums FROM `report` r
                    RIGHT JOIN report_item i ON r.id=i.report_id
                    RIGHT JOIN report_item_drugs d ON d.report_item_id=i.id
                    WHERE r.report_status=2 AND r.add_date BETWEEN '2020-01-01' AND '2020-12-30' 
                    GROUP BY i.project_id,d.antibiotic_dict_id,d.drugs_result
              )  A
              GROUP BY A.project_name,A.antibiotic_dict_name
        ) AA 
        RIGHT JOIN 
        (
              SELECT i.project_name,d.antibiotic_dict_name,IF(d.drugs_result<>'', d.drugs_result, '未填寫') AS drugs_result,COUNT(d.id) AS 數(shù)量 
              FROM `report` r
              RIGHT JOIN report_item i ON r.id=i.report_id
              RIGHT JOIN report_item_drugs d ON d.report_item_id=i.id
              WHERE r.report_status=2 AND r.add_date BETWEEN '2020-01-01' AND '2020-12-30' 
              GROUP BY i.project_id,d.antibiotic_dict_id,d.drugs_result            
        )BB ON AA.project_name=BB.project_name AND AA.antibiotic_dict_name=BB.antibiotic_dict_name
    WHERE AA.`檢出總數(shù)`<>''

4、一般來說,到上一步不同藥敏數(shù)量和總數(shù)都有了,可以直接求比例了

但是,我們需要的是將藥敏顯示到行上,直接求比不符合需求,所以我們需要將列轉(zhuǎn)換為行

我們借助于case when實現(xiàn)行列轉(zhuǎn)換,并將藥敏結(jié)果根據(jù)字典轉(zhuǎn)為方便閱讀的漢字


SELECT
  C.project_name 項目名稱,C.antibiotic_dict_name 抗生素名稱,C.`檢出總數(shù)`,
  SUM(CASE C.`drugs_result` WHEN 'D' THEN C.`數(shù)量` ELSE 0 END ) AS '劑量依賴性敏感',
  CONCAT(SUM(CASE C.`drugs_result` WHEN 'D' THEN FORMAT(C.`數(shù)量`/C.`檢出總數(shù)`*100,2) ELSE 0 END),'%') AS '劑量依賴性敏感比率',
  SUM(CASE C.`drugs_result` WHEN 'R' THEN C.`數(shù)量` ELSE 0 END ) AS '耐藥',
  CONCAT(SUM(CASE C.`drugs_result` WHEN 'R' THEN FORMAT(C.`數(shù)量`/C.`檢出總數(shù)`*100,2) ELSE 0 END),'%') AS '耐藥比率',
  SUM(CASE C.`drugs_result` WHEN 'S' THEN C.`數(shù)量` ELSE 0 END ) AS '敏感',
  CONCAT(SUM(CASE C.`drugs_result` WHEN 'S' THEN FORMAT(C.`數(shù)量`/C.`檢出總數(shù)`*100,2) ELSE 0 END),'%') AS '敏感比率',
  SUM(CASE C.`drugs_result` WHEN 'I' THEN C.`數(shù)量` ELSE 0 END ) AS '中介',
  CONCAT(SUM(CASE C.`drugs_result` WHEN 'I' THEN FORMAT(C.`數(shù)量`/C.`檢出總數(shù)`*100,2) ELSE 0 END),'%') AS '中介比率',
  SUM(CASE C.`drugs_result` WHEN 'n1' THEN C.`數(shù)量` ELSE 0 END ) AS '非敏感',
  CONCAT(SUM(CASE C.`drugs_result` WHEN 'n1' THEN FORMAT(C.`數(shù)量`/C.`檢出總數(shù)`*100,2) ELSE 0 END),'%') AS '非敏感比率',
  SUM(CASE C.`drugs_result` WHEN 'N' THEN C.`數(shù)量` ELSE 0 END ) AS '無',
  CONCAT(SUM(CASE C.`drugs_result` WHEN 'N' THEN FORMAT(C.`數(shù)量`/C.`檢出總數(shù)`*100,2) ELSE 0 END),'%') AS '無比率',
  SUM(CASE C.`drugs_result` WHEN '未填寫' THEN C.`數(shù)量` ELSE 0 END ) AS '未填寫',
  CONCAT(SUM(CASE C.`drugs_result` WHEN '未填寫' THEN FORMAT(C.`數(shù)量`/C.`檢出總數(shù)`*100,2) ELSE 0 END),'%') AS '未填寫比率'
FROM
(
    SELECT 
      BB.project_name,BB.antibiotic_dict_name,BB.drugs_result,BB.`數(shù)量`,AA.`檢出總數(shù)`
    FROM 
        (
              SELECT 
                A.project_name,A.antibiotic_dict_name,SUM(nums) AS 檢出總數(shù)
              FROM 
              (
                    SELECT i.project_name,d.antibiotic_dict_name,d.drugs_result,COUNT(d.id) AS nums FROM `report` r
                    RIGHT JOIN report_item i ON r.id=i.report_id
                    RIGHT JOIN report_item_drugs d ON d.report_item_id=i.id
                    WHERE r.report_status=2 AND r.add_date BETWEEN '2020-01-01' AND '2020-12-30' 
                    GROUP BY i.project_id,d.antibiotic_dict_id,d.drugs_result
              )  A
              GROUP BY A.project_name,A.antibiotic_dict_name
        ) AA 
        RIGHT JOIN 
        (
              SELECT i.project_name,d.antibiotic_dict_name,IF(d.drugs_result<>'', d.drugs_result, '未填寫') AS drugs_result,COUNT(d.id) AS 數(shù)量 
              FROM `report` r
              RIGHT JOIN report_item i ON r.id=i.report_id
              RIGHT JOIN report_item_drugs d ON d.report_item_id=i.id
              WHERE r.report_status=2 AND r.add_date BETWEEN '2020-01-01' AND '2020-12-30' 
              GROUP BY i.project_id,d.antibiotic_dict_id,d.drugs_result            
        )BB ON AA.project_name=BB.project_name AND AA.antibiotic_dict_name=BB.antibiotic_dict_name
    WHERE AA.`檢出總數(shù)`<>''                                        
) C
GROUP BY C.project_name,C.antibiotic_dict_name;

5、查看結(jié)果,成功轉(zhuǎn)換


到此這篇關(guān)于mysql 行列轉(zhuǎn)換的示例代碼的文章就介紹到這了,更多相關(guān)mysql 行列轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解關(guān)于MySQL 8.0走過的坑

    詳解關(guān)于MySQL 8.0走過的坑

    這篇文章主要介紹了詳解關(guān)于MySQL 8.0走過的坑,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • SQL?FOREIGN?KEY約束保障表之間關(guān)系完整性關(guān)鍵規(guī)則詳解

    SQL?FOREIGN?KEY約束保障表之間關(guān)系完整性關(guān)鍵規(guī)則詳解

    這篇文章主要介紹了SQL?FOREIGN?KEY約束保障表之間關(guān)系完整性關(guān)鍵規(guī)則詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • centos7上mysql8.0rpm方式安裝教程圖解

    centos7上mysql8.0rpm方式安裝教程圖解

    這篇文章主要介紹了centos7上mysql8.0rpm方式安裝教程,本文圖文并茂給大家介紹的非常詳細,具有參考借鑒價值,需要的朋友可以參考下
    2018-04-04
  • SQL觸發(fā)器定義與使用

    SQL觸發(fā)器定義與使用

    SQL的觸發(fā)器和存儲過程一樣,都是嵌入到SQL中的一段程序,是SQL中管理數(shù)據(jù)的有力工具,本文給大家詳細介紹SQL觸發(fā)器的定義語法知識,感興趣的朋友一起看看吧
    2023-01-01
  • 如何提高MySQL Limit查詢性能的方法詳解

    如何提高MySQL Limit查詢性能的方法詳解

    今天小編就為大家分享一篇關(guān)于如何提高MySQL Limit查詢性能的方法詳解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • MySQL服務(wù)自動停止的解決方法

    MySQL服務(wù)自動停止的解決方法

    這篇文章主要給大家介紹了MySQL服務(wù)自動停止的解決方法,文中給出了詳細的解決過程,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-06-06
  • MySQL數(shù)據(jù)庫show processlist指令使用解析

    MySQL數(shù)據(jù)庫show processlist指令使用解析

    這篇文章主要介紹了MySQL數(shù)據(jù)庫show processlist指令使用解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • mysql變量用法實例分析【系統(tǒng)變量、用戶變量】

    mysql變量用法實例分析【系統(tǒng)變量、用戶變量】

    這篇文章主要介紹了mysql變量用法,結(jié)合實例形式分析了mysql系統(tǒng)變量、用戶變量相關(guān)概念、功能、原理與使用技巧,需要的朋友可以參考下
    2020-04-04
  • MySQL優(yōu)化案例之隱式字符編碼轉(zhuǎn)換

    MySQL優(yōu)化案例之隱式字符編碼轉(zhuǎn)換

    這篇文章主要介紹了MySQL優(yōu)化案例之隱式字符編碼轉(zhuǎn)換,隱式類型轉(zhuǎn)換也會導(dǎo)致同樣的放棄走樹搜索,更多相關(guān)內(nèi)容具有一定的參考價值,需要的朋友可以參考一下
    2022-07-07
  • Centos7使用yum安裝Mysql5.7.19的詳細步驟

    Centos7使用yum安裝Mysql5.7.19的詳細步驟

    本篇文章主要介紹了Centos7使用yum安裝Mysql5.7.19的詳細步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09

最新評論