查询显示相同信息的多个列表

时间:2013-09-10 19:05:04

标签: sql

我正在使用此查询来查找网络上的所有计算机(使用dell kace),这些计算机根据其服务标签具有过期保修。

但是,当我运行查询时,某些机器会列出两次,但只应列出一次。

以下是输出示例,其中正确列出了机器示例3,但是示例1列出了两次。

#      Machine Name     Service Tag

1       example1           abcd123

2       example1           abcd123

3       example3            abcd124

代码:

SELECT     

M.NAME AS MACHINE_NAME, M.CS_MODEL AS MODEL, DA.SERVICE_TAG,
DA.SHIP_DATE,M.USER_LOGGED AS LAST_LOGGED_IN_USER, DW.SERVICE_LEVEL_CODE,
DW.SERVICE_LEVEL_DESCRIPTION, DW.END_DATE AS EXPIRATION_DATE

FROM

DELL_WARRANTY DW

JOIN

DELL_ASSET DA ON (DW.SERVICE_TAG = DA.SERVICE_TAG)

JOIN

MACHINE M

ON (M.BIOS_SERIAL_NUMBER = DA.PARENT_SERVICE_TAG OR M.BIOS_SERIAL_NUMBER = DA.SERVICE_TAG)

LEFT JOIN

DELL_WARRANTY DW2 ON DW2.SERVICE_TAG=DW.SERVICE_TAG and DW2.END_DATE > NOW()

WHERE

M.CS_MANUFACTURER LIKE '%dell%'

AND

M.BIOS_SERIAL_NUMBER!=''

AND

 DA.DISABLED != 1

AND

DW.END_DATE < NOW()

AND

DW2.SERVICE_TAG IS NULL;

关于如何使用相同的机器名称和服务标签制作计算机的任何想法只输出一次?谢谢。

2 个答案:

答案 0 :(得分:1)

让我假设您拥有合理的数据模型和合理填充的数据。这意味着重复项不是来自存储在数据库中的不适当数据。

您的查询(格式化,以便我可以阅读)是:

SELECT M.NAME AS MACHINE_NAME, M.CS_MODEL AS MODEL, DA.SERVICE_TAG,
       DA.SHIP_DATE, M.USER_LOGGED AS LAST_LOGGED_IN_USER, DW.SERVICE_LEVEL_CODE,
       DW.SERVICE_LEVEL_DESCRIPTION, DW.END_DATE AS EXPIRATION_DATE
FROM DELL_WARRANTY DW JOIN
     DELL_ASSET DA
     ON DW.SERVICE_TAG = DA.SERVICE_TAG JOIN
     MACHINE M
     ON M.BIOS_SERIAL_NUMBER = DA.PARENT_SERVICE_TAG OR
        M.BIOS_SERIAL_NUMBER = DA.SERVICE_TAG LEFT JOIN
     DELL_WARRANTY DW2
     ON DW2.SERVICE_TAG = DW.SERVICE_TAG and DW2.END_DATE > NOW()
WHERE M.CS_MANUFACTURER LIKE '%dell%' AND
      M.BIOS_SERIAL_NUMBER <> '' AND
      DA.DISABLED <> 1;

嫌疑人joinMachine上的嫌疑人,因为它有or。因此,两台机器可能匹配服务标签的不同部分,从而产生多个非常相似的行。

如果您关心的是机器名称和服务标签(问题中突出显示的两列),那么您可以通过以下结束查询来修复这些重复项:

group by M.NAME, DA.SERVICE_TAG

(这假设您正在使用MySQL - 基于查询的语法。大多数其他数据库需要围绕select中其余列的聚合函数。)

答案 1 :(得分:0)

尝试在M.Name

前面放置一个DISTINCT

或者玩

之类的联接
 SELECT     

M.NAME AS MACHINE_NAME, M.CS_MODEL AS MODEL, DA.SERVICE_TAG,
DA.SHIP_DATE,M.USER_LOGGED AS LAST_LOGGED_IN_USER, DW.SERVICE_LEVEL_CODE,
DW.SERVICE_LEVEL_DESCRIPTION, DW.END_DATE AS EXPIRATION_DATE

FROM

DELL_WARRANTY DW

INNER JOIN

DELL_ASSET DA ON (DW.SERVICE_TAG = DA.SERVICE_TAG)

INNER JOIN

 MACHINE M

ON (M.BIOS_SERIAL_NUMBER = DA.PARENT_SERVICE_TAG OR M.BIOS_SERIAL_NUMBER = DA.SERVICE_TAG)

INNER JOIN

DELL_WARRANTY DW2 ON DW2.SERVICE_TAG=DW.SERVICE_TAG and DW2.END_DATE > NOW()

 WHERE

M.CS_MANUFACTURER LIKE '%dell%'

AND

M.BIOS_SERIAL_NUMBER!=''

AND

DA.DISABLED != 1

AND

DW.END_DATE < NOW()

AND

DW2.SERVICE_TAG IS NULL;