我写了一个下面提到的查询,我需要在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)
我错过了什么吗?请建议我最好的解决方案
第一个查询列出了在所有选定列中不同的行。第二个查询计算单个列E.EMP_CODE
中的不同值。
E.EMP_CODE A.EMP_ID ...
1 2 ...
1 3 ...
第一个查询的两个不同的行,但E.EMP_CODE
只有一个不同的count
。
因为在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
| COL1 | COL2 |
|------|------|
| A | B1 |
| A | B |
| AB | B3 |
查询2:
SELECT COUNT(DISTINCT col1)
FROM T
| COUNT(DISTINCTCOL1) |
|---------------------|
| 2 |
你可以使用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
可能是你有一些重复的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仅返回列中不同值的数量