SQL查询中的记录数错误

问题描述 投票:0回答:4

我写了一个下面提到的查询,我需要在GUI中准备列表,我需要显示总记录的数量,现在我的记录是119这是正确的但是当我应用计数功能时它变为115.我想知道为什么它是发生。

SELECT distinct E.EMP_CODE,
  a.EMP_ID,
  e.name,
  E.ADHAR_NO,
  a.CURRENT_STATUS,
  D.NAME
FROM ACR a
JOIN EMPLOYEE E
ON E.EMP_ID=a.EMP_ID
JOIN DESIGNATION D
ON D.DESIGNATION_ID      =E.DESIGNATION_ID
AND e.EMP_TYPE_ID NOT   IN(02,03,04,06,08)
AND (e.DESIGNATION_ID   IN (23,99)
OR d.DESIGNATION_CLASS IN(1,2))
AND (e.relief_type      IS NULL
OR e.RELIEF_TYPE         = 4)
JOIN REGION R
ON R.REGION_ID=E.REGION_ID
LEFT JOIN CIRCLE C
ON C.CIRCLE_ID       =E.CIRCLE_ID
WHERE ACR_FOR_SESSION='2017-2018'
AND E.CIRCLE_ID     IS NULL
AND E.REGION_ID      =1
AND a.CURRENT_STATUS>1

总记录清单是119

现在应用DISTINCT E.EMP_CODE计数

SELECT count(distinct E.EMP_CODE)
FROM ACR a
JOIN EMPLOYEE E
ON E.EMP_ID=a.EMP_ID
JOIN DESIGNATION D
ON D.DESIGNATION_ID      =E.DESIGNATION_ID
AND e.EMP_TYPE_ID NOT   IN(02,03,04,06,08)
AND (e.DESIGNATION_ID   IN (23,99)
OR d.DESIGNATION_CLASS IN(1,2))
AND (e.relief_type      IS NULL
OR e.RELIEF_TYPE         = 4)
JOIN REGION R
ON R.REGION_ID=E.REGION_ID
LEFT JOIN CIRCLE C
ON C.CIRCLE_ID       =E.CIRCLE_ID
WHERE ACR_FOR_SESSION='2017-2018'
AND E.CIRCLE_ID     IS NULL
AND E.REGION_ID      =1
AND a.CURRENT_STATUS>1

Output: 115 (Wrong)

我错过了什么吗?请建议我最好的解决方案

sql oracle oracle11g oracle-sqldeveloper
4个回答
1
投票

第一个查询列出了在所有选定列中不同的行。第二个查询计算单个列E.EMP_CODE中的不同值。

E.EMP_CODE A.EMP_ID ...
1          2        ...
1          3        ...

第一个查询的两个不同的行,但E.EMP_CODE只有一个不同的count


1
投票

因为在E.EMP_CODE有一些E.EMP_CODE行相同。当你使用count(distinct E.EMP_CODE)时只从E.EMP_CODE删除相同的值然后得到COUNT

但是当你使用的时候

distinct E.EMP_CODE,
  a.EMP_ID,
  e.name,
  E.ADHAR_NO,
  a.CURRENT_STATUS,
  D.NAME

将删除所有这些相同的值。

这是一个例子。

CREATE TABLE T(col1 varchar(50),col2 varchar(50));

INSERT INTO T VALUES ('A','B'); 
INSERT INTO T VALUES ('A','B1'); 
INSERT INTO T VALUES ('AB','B3'); 

查询1:

SELECT DISTINCT * 
FROM T

Results

| COL1 | COL2 |
|------|------|
|    A |   B1 |
|    A |    B |
|   AB |   B3 |

查询2:

SELECT COUNT(DISTINCT col1)
FROM T

Results

| COUNT(DISTINCTCOL1) |
|---------------------|
|                   2 |

1
投票

你可以使用group by,因为在你的第一个查询中,grouply make distinct所以也适用于第二个查询

select sum(cnt)  from
        (
       SELECT count(E.EMP_CODE) as cnt
        FROM ACR a
        JOIN EMPLOYEE E
        ON E.EMP_ID=a.EMP_ID
        JOIN DESIGNATION D
        ON D.DESIGNATION_ID      =E.DESIGNATION_ID
        AND e.EMP_TYPE_ID NOT   IN(02,03,04,06,08)
        AND (e.DESIGNATION_ID   IN (23,99)
        OR d.DESIGNATION_CLASS IN(1,2))
        AND (e.relief_type      IS NULL
        OR e.RELIEF_TYPE         = 4)
        JOIN REGION R
        ON R.REGION_ID=E.REGION_ID
        LEFT JOIN CIRCLE C
        ON C.CIRCLE_ID       =E.CIRCLE_ID
        WHERE ACR_FOR_SESSION='2017-2018'
        AND E.CIRCLE_ID     IS NULL
        AND E.REGION_ID      =1
        AND a.CURRENT_STATUS>1
       group by 
       a.EMP_ID,
      e.name,
      E.ADHAR_NO,
      a.CURRENT_STATUS,
      D.NAME
      ) t

0
投票

可能是你有一些重复的e.emp_code值...,例如:emp_code有更多的行

尝试避免在你的数量

  SELECT count(E.EMP_CODE)
  FROM ACR a
  JOIN EMPLOYEE E
  ON E.EMP_ID=a.EMP_ID
  JOIN DESIGNATION D
  ON D.DESIGNATION_ID      =E.DESIGNATION_ID
  AND e.EMP_TYPE_ID NOT   IN(02,03,04,06,08)
  AND (e.DESIGNATION_ID   IN (23,99)
  OR d.DESIGNATION_CLASS IN(1,2))
  AND (e.relief_type      IS NULL
  OR e.RELIEF_TYPE         = 4)
  JOIN REGION R
  ON R.REGION_ID=E.REGION_ID
  LEFT JOIN CIRCLE C
  ON C.CIRCLE_ID       =E.CIRCLE_ID
  WHERE ACR_FOR_SESSION='2017-2018'
  AND E.CIRCLE_ID     IS NULL
  AND E.REGION_ID      =1
  AND a.CURRENT_STATUS>1

distinct count仅返回列中不同值的数量

© www.soinside.com 2019 - 2024. All rights reserved.