1. 需要3 つのテーブルがあります。一定期間にわたるさまざまな抗生物質感受性の結果、つまり report_item_drugs テーブルの drugs_result、さまざまなプロジェクト project_name およびさまざまな抗生物質 antibiotic_dict_name の割合を分類してカウントし、行に薬剤感受性の結果を表示する必要があります。効果は次のとおりです。 元の 3 つのテーブル (必須フィールドのみを例として挙げています) は次のとおりです。 報告書フォーム プロジェクトリスト 抗生物質テーブル(薬剤感受性結果 drugs_result は値の列です) 2. 実装1. プロジェクトと抗生物質グループ別に検出された症例の総数を計算する 選択 A.project_name、A.antibiotic_dict_name、SUM(nums) AS 検出総数 FROM ( SELECT i.project_name,d.antibiotic_dict_name,d.drugs_result,COUNT(d.id) AS nums FROM `report` r 右結合 report_item i ON r.id=i.report_id 右結合 report_item_drugs d ON d.report_item_id=i.id r.report_status=2 かつ r.add_date が '2020-01-01' から '2020-12-30' の間 i.project_id、d.antibiotic_dict_id、d.drugs_result でグループ化 )A GROUP BY A.プロジェクト名、A.抗生物質辞書名 2. プロジェクト、抗生物質、薬剤感受性結果に応じて、異なる薬剤感受性結果の数を計算する SELECT i.project_name,d.antibiotic_dict_name,IF(d.drugs_result<>'', d.drugs_result, '未入力') AS drugs_result,COUNT(d.id) AS quantity FROM `report` r 右結合 report_item i ON r.id=i.report_id 右結合 report_item_drugs d ON d.report_item_id=i.id r.report_status=2 かつ r.add_date が '2020-01-01' から '2020-12-30' の間 i.project_id、d.antibiotic_dict_id、d.drugs_result でグループ化 3. 2つの結果をリンクする 選択 BB.project_name、BB.antibiotic_dict_name、BB.drugs_result、BB.`quantity`、AA.`検出総数` から ( 選択 A.project_name、A.antibiotic_dict_name、SUM(nums) AS 検出総数 FROM ( SELECT i.project_name,d.antibiotic_dict_name,d.drugs_result,COUNT(d.id) AS nums FROM `report` r 右結合 report_item i ON r.id=i.report_id 右結合 report_item_drugs d ON d.report_item_id=i.id r.report_status=2 かつ r.add_date が '2020-01-01' から '2020-12-30' の間 i.project_id、d.antibiotic_dict_id、d.drugs_result でグループ化 )A GROUP BY A.プロジェクト名、A.抗生物質辞書名 ) AA 右結合 ( SELECT i.project_name,d.antibiotic_dict_name,IF(d.drugs_result<>'', d.drugs_result, '未入力') AS drugs_result,COUNT(d.id) AS quantity FROM `report` r 右結合 report_item i ON r.id=i.report_id 右結合 report_item_drugs d ON d.report_item_id=i.id r.report_status=2 かつ r.add_date が '2020-01-01' から '2020-12-30' の間 i.project_id、d.antibiotic_dict_id、d.drugs_result でグループ化 )BB ON AA.project_name=BB.project_name かつ AA.antibiotic_dict_name=BB.antibiotic_dict_name ここで、AA.`検出総数`<>' 4. 一般的に、異なる薬剤感受性の数と合計数は前のステップで入手できるため、比率を直接計算できます。 しかし、必要なのは薬剤感受性を行に表示することであり、比率を直接計算するだけでは要件を満たさないため、列を行に変換する必要があります。 行と列を変換する際にはcaseを使用し、薬物感受性の結果を辞書に従って読みやすい中国語の文字に変換します。 選択 C.project_name プロジェクト名、C.antibiotic_dict_name 抗生物質名、C.`検出総数`、 SUM(CASE C.`drugs_result` WHEN 'D' THEN C.`Quantity` ELSE 0 END ) AS '用量依存感度', CONCAT(SUM(CASE C.`drugs_result` WHEN 'D' THEN FORMAT(C.`Quantity`/C.`Total number of detections`*100,2) ELSE 0 END),'%') AS '用量依存感度比', SUM(CASE C.`drugs_result` WHEN 'R' THEN C.`Quantity` ELSE 0 END ) AS '薬剤耐性', CONCAT(SUM(CASE C.`drugs_result` WHEN 'R' THEN FORMAT(C.`Quantity`/C.`Total number of detections`*100,2) ELSE 0 END),'%') AS '薬剤耐性率', SUM(CASE C.`drugs_result` WHEN 'S' THEN C.`Quantity` ELSE 0 END ) AS 'Sensitive', CONCAT(SUM(CASE C.`drugs_result` WHEN 'S' THEN FORMAT(C.`Quantity`/C.`Total number of detections`*100,2) ELSE 0 END),'%') AS 'Sensitive ratio', SUM(CASE C.`drugs_result` WHEN 'I' THEN C.`Quantity` ELSE 0 END ) AS 'Agency', CONCAT(SUM(CASE C.`drugs_result` WHEN 'I' THEN FORMAT(C.`Quantity`/C.`Total Detection`*100,2) ELSE 0 END),'%') AS '中間比率', SUM(CASE C.`drugs_result` WHEN 'n1' THEN C.`quantity` ELSE 0 END ) AS 'non-sensitive', CONCAT(SUM(CASE C.`drugs_result` WHEN 'n1' THEN FORMAT(C.`Quantity`/C.`Total number of detections`*100,2) ELSE 0 END),'%') AS '非感受性比率', SUM(CASE C.`drugs_result` WHEN 'N' THEN C.`Quantity` ELSE 0 END ) AS 'None', CONCAT(SUM(CASE C.`drugs_result` WHEN 'N' THEN FORMAT(C.`Quantity`/C.`Total Detection`*100,2) ELSE 0 END),'%') AS '比率なし', SUM(CASE C.`drugs_result` WHEN '未記入' THEN C.`Quantity` ELSE 0 END ) AS '未記入', CONCAT(SUM(CASE C.`drugs_result` WHEN '未記入' THEN FORMAT(C.`数量`/C.`検出総数`*100,2) ELSE 0 END),'%') AS '未記入比率' から ( 選択 BB.project_name、BB.antibiotic_dict_name、BB.drugs_result、BB.`quantity`、AA.`検出総数` から ( 選択 A.project_name、A.antibiotic_dict_name、SUM(nums) AS 検出総数 FROM ( SELECT i.project_name,d.antibiotic_dict_name,d.drugs_result,COUNT(d.id) AS nums FROM `report` r 右結合 report_item i ON r.id=i.report_id 右結合 report_item_drugs d ON d.report_item_id=i.id r.report_status=2 かつ r.add_date が '2020-01-01' から '2020-12-30' の間 i.project_id、d.antibiotic_dict_id、d.drugs_result でグループ化 )A GROUP BY A.プロジェクト名、A.抗生物質辞書名 ) AA 右結合 ( SELECT i.project_name,d.antibiotic_dict_name,IF(d.drugs_result<>'', d.drugs_result, '未入力') AS drugs_result,COUNT(d.id) AS quantity FROM `report` r 右結合 report_item i ON r.id=i.report_id 右結合 report_item_drugs d ON d.report_item_id=i.id r.report_status=2 かつ r.add_date が '2020-01-01' から '2020-12-30' の間 i.project_id、d.antibiotic_dict_id、d.drugs_result でグループ化 )BB ON AA.project_name=BB.project_name かつ AA.antibiotic_dict_name=BB.antibiotic_dict_name ここで、AA.`検出総数`<>' )C GROUP BY C.プロジェクト名、C.抗生物質辞書名; 5. 結果を確認し、変換に成功する MySQL の行と列の変換のサンプルコードに関するこの記事はこれで終わりです。MySQL の行と列の変換に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: ブラウザでのjsのイベントループイベントキューの詳細な説明
1. フォーム<form id="" name="" ...
vue2 では、タイムスタンプを変換するときに、通常はフィルターを使用します。vue3 以降では、...
目次序文デモンストレーション効果HTMLコードCSSコードJavascriptコードデモアドレス序文...
マスタースレーブ同期 (マスタースレーブレプリケーションとも呼ばれる) は、マスタースレーブデータの...
CSS を使用して、左側に固定幅、右側に適応幅を持つ 2 列レイアウトを実装する 7 つの方法。コー...
目次1. イメージをプルする1.1 関連するイメージをプルして実行する1.1.1 関連する画像を取得...
目次序文数独の解き方最初のボックスに記入してください2番目のボックスに記入してください3番目のボック...
目次1. マップ方式2. 応用背景:需要開発プロセス中に、一部のインターフェースは、ページに表示する...
内容Hyperledger fabric1.4環境のWindows 10でのセットアップ前提条件Wi...
私は通常、大手ウェブサイトの特別ページや製品リリースページを訪問するのが好きです。なぜなら、たくさん...
この記事では主に、v-if と v-for を一緒に使用することが推奨されない理由を紹介します。詳細...
CSS における位置指定の概要position属性は英語で位置を意味し、 CSSでの主な機能は要素...
1. コマンドの紹介userdel (ユーザー削除) コマンドは、ユーザー アカウントと関連ファイル...
目次1.1Tinyint型の説明1.2 練習環境の説明1.3 未署名属性の追加1.3.1 SQLモー...
HTML の一般的なコメント: <!--XXXXXXXX--> (XXXXXXXX はコ...