0
SELECT table2.*, 
       (SELECT Sum(qtde) 
        FROM   table1 
        WHERE  table1.cnes = table2.cnes 
               AND table1.procedimento = table2.procedimento 
               AND table1.mes = table2.mes 
               AND table1.ano = table2.ano 
        GROUP  BY cnes, 
                  procedimento, 
                  ano, 
                  mes) AS soma 
FROM   table2 

此代码在 Access 中运行良好。

我有两张桌子。

表 1 有以下列:CNES, PROCEDIMENTO, MES, ANO, QTDE

它可能包含这样的信息(我无法改变这个事实,我从另一个软件获取信息)

+------+--------------+-----+-----+------+
| CNES | PROCEDIMENTO | MES | ANO | QTDE |
+------+--------------+-----+-----+------+
| C1   | P1           | M1  | A1  |   12 |
| C1   | P1           | M1  | A1  |    3 |
| C1   | P1           | M1  | A1  |    5 |
| C1   | P2           | M1  | A1  |    4 |
| C1   | P2           | M1  | A1  |    4 |
| C1   | P2           | M1  | A1  |    3 |
| C1   | P3           | M1  | A1  |    4 |
| C2   | P2           | M1  | A1  |    5 |
| C2   | P2           | M1  | A1  |    4 |
| C2   | P1           | M1  | A1  |    3 |
+------+--------------+-----+-----+------+

QTDE = 手术数量 (PROCEDIMENTO),来自医院 (CNES),在一个月 (MES) 和一年 (ANO) 内完成

因此,要知道从一家医院到一个月的手术数量,我需要搜索所有行并将该月的所有行相加......

表 2 有以下列:CNES, PROCEDIMENTO, NOME, MES, ANO, META

此表包含医院在一个月内需要执行的程序数量(META)和程序的实际名称(NOME。PROCEDIMENTO 是一个数字,但我将其存储为字符串 [code])

因此,在 Access 中工作的我的查询将从上面的示例中执行此操作

查询1

+------+--------------+------+-----+-----+------+------------+
| CNES | PROCEDIMENTO | NOME | MES | ANO | META | SUM(QTDE)  |
+------+--------------+------+-----+-----+------+------------+
| C1   | P1           | N1   | M1  | A1  |   23 |         20 |
| C1   | P2           | N2   | M1  | A1  |   20 |         11 |
| C1   | P3           | N3   | M1  | A1  |   04 |          4 |
| C2   | P2           | N2   | M1  | A1  |   05 |          9 |
| C2   | P1           | N1   | M1  | A1  |   01 |          3 |
+------+--------------+------+-----+-----+------+------------+

如果你仔细观察,你会发现最后一列是那个月的数量总和,所以我可以用它来看看医院是否做了它应该在那个月做的手术数量。

除此之外,我的查询没有这样做,但我希望它这样做......我需要另一列来显示 % (SUM(QTDE)/META)。但是我需要使超过 100% 的 %% 成为 100% ......而且我需要小心除以零问题......

4

1 回答 1

0

我认为这在 MySQL 5.5.30 中运行良好:

select *, 
 if(meta = 0 or soma > meta, 100, (soma/meta)*100) Percent
from
(
 SELECT table2.*, 
   (SELECT Sum(qtde) 
    FROM   table1 
    WHERE  table1.cnes = table2.cnes 
           AND table1.procedimento = table2.procedimento 
           AND table1.mes = table2.mes 
           AND table1.ano = table2.ano 
    GROUP  BY cnes, 
              procedimento, 
              ano, 
              mes) AS soma
FROM   table2) TMP;
于 2013-03-20T23:27:40.193 回答