[英]SQL Distinct keyword not returning distinct values for Multiple Columns
If i select only 1 column with Distinct then it's working fine if i select multiple columns with 1 distinct it returns duplicate values .. 如果我只选择1个具有Distinct的列,则工作正常,如果我选择了1个不同的多列,则返回重复值..
SELECT
DISTINCT MS.SRC_TABLE_NAME AS SRC_TABLE_NAME,
MS.SRC_SYSTEM_ENVIRONMENT_NAME AS SRC_SYSTEM_ENVIRONMENT_NAME,
MS.SRC_SYSTEM_NAME AS SRC_SYSTEM_NAME
FROM
MAPPING_SPECIFICATION MS,
MAPPING_DETAILS MD
WHERE
MS.MAP_ID = MD.MAP_ID AND
MD.STATUS = 'Active'
Returns Duplicate rows 返回重复行
SELECT
DISTINCT MS.SRC_TABLE_NAME AS SRC_TABLE_NAME
FROM
MAPPING_SPECIFICATION MS,
MAPPING_DETAILS MD
WHERE
MS.MAP_ID = MD.MAP_ID AND
MD.STATUS = 'Active'
Works Perfectly if select only Distinct Row . 如果仅选择Distinct Row,则效果很好。
DISTINCT
does not guarantee you have SRC_TABLE_NAME
unique when you use it with other columns. DISTINCT
不保证您将SRC_TABLE_NAME
与其他列一起使用时具有唯一性。 Your rows are DISTINCT
and it works perfectly fine 您的行是
DISTINCT
,效果很好
CREATE TABLE #MyTable(col1 INT, col2 INT);
INSERT INTO #MyTable VALUES (1,1), (1,2), (2,1),(3,1);
SELECT DISTINCT col1, col2
FROM #MyTable;
Use GROUP BY
instead with aggregate function
like MIN/MAX/GROUP_CONCAT
: 使用
GROUP BY
代替MIN/MAX/GROUP_CONCAT
类的aggregate function
:
SELECT
MS.SRC_TABLE_NAME AS SRC_TABLE_NAME,
MIN(MS.SRC_SYSTEM_ENVIRONMENT_NAME) AS SRC_SYSTEM_ENVIRONMENT_NAME,
MIN(MS.SRC_SYSTEM_NAME) AS SRC_SYSTEM_NAME
FROM MAPPING_SPECIFICATION MS
JOIN MAPPING_DETAILS MD
ON MS.MAP_ID = MD.MAP_ID AND
WHERE MD.STATUS = 'Active'
GROUP BY MS.SRC_TABLE_NAME;
Also try to avoid comma syntax join and use JOIN
. 也请尝试避免使用逗号语法
JOIN
并使用JOIN
。 Keep in mind that SQL Server
and MySQL
support different aggregate functions. 请记住,
SQL Server
和MySQL
支持不同的聚合函数。
You can try like this to get DISTINCT with multiple columns: 您可以尝试这样获得具有多个列的DISTINCT:
select
(SELECT group_concat(DISTINCT MS.SRC_TABLE_NAME) FROM MAPPING_SPECIFICATION MS INNER JOIN MAPPING_DETAILS MD ON MS.MAP_ID = MD.MAP_ID
WHERE MD.STATUS = 'Active') as SRC_TABLE_NAME,
(SELECT group_concat(DISTINCT MS.SRC_SYSTEM_ENVIRONMENT_NAME) FROM MAPPING_SPECIFICATION MS INNER JOIN MAPPING_DETAILS MD ON MS.MAP_ID = MD.MAP_ID
WHERE MD.STATUS = 'Active') as SRC_SYSTEM_ENVIRONMENT_NAME,
(SELECT group_concat(DISTINCT MS.SRC_SYSTEM_NAM) FROM MAPPING_SPECIFICATION MS INNER JOIN MAPPING_DETAILS MD ON MS.MAP_ID = MD.MAP_ID
WHERE MD.STATUS = 'Active') as SRC_SYSTEM_NAME
Its in MYSQL. 它在MYSQL中。
In SQL Server you can use Group By like this: 在SQL Server中,您可以这样使用Group By:
SELECT MS.SRC_SYSTEM_NAM AS SRC_TABLE_NAME,
MS.SRC_SYSTEM_ENVIRONMENT_NAME AS SRC_SYSTEM_ENVIRONMENT_NAME,
MS.SRC_SYSTEM_NAME AS SRC_SYSTEM_NAME
FROM MAPPING_SPECIFICATION MS
INNER JOIN MAPPING_DETAILS MD ON MS.MAP_ID = MD.MAP_ID
WHERE MD.STATUS = 'Active'
GROUP BY MS.SRC_SYSTEM_NAM, MS.SRC_SYSTEM_ENVIRONMENT_NAME, MS.SRC_SYSTEM_NAME
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.