2

我有一个 postgreSQL 查询,它应该是我们实验室的实际样本库存。初始样本取自一个表 (tblStudies),但随后需要查找 2 个表以减少样本量。所以我对这两个表进行了联合查询,然后将 uniun 查询与 tblStudies 匹配以计算实际库存。但是联合查询仅在样本减少时才给出值。因此,当研究仍然具有初始样本时,不会返回该值。我想我应该使用 JOIN 操作,但是我的研究中有初始样本的 NULL 值。

这是我走了多远,请帮忙吗?

SELECT
    "tblStudies"."Studie_ID", "SamplesWeggezet", c."Stalen_gebruikt", "SamplesWeggezet" - c."Stalen_gebruikt" as "Stock"
FROM
    "Stability"."tblStudies"
    LEFT JOIN
    (
        SELECT b."Studie_ID",sum(b."Stalen_gebruikt") as "Stalen_gebruikt"
        FROM (
            SELECT "tblAnalyses"."Studie_ID", sum("tblAnalyses"."Aant_stalen_gebruikt") AS "Stalen_gebruikt"
            FROM "Stability"."tblAnalyses"
            GROUP BY "tblAnalyses"."Studie_ID"
            UNION 
            SELECT "tblStalenUitKamer"."Studie_ID", sum("tblStalenUitKamer".aant_stalen) AS "stalen_gebruikt"
            FROM "Stability"."tblStalenUitKamer"
            GROUP BY "tblStalenUitKamer"."Studie_ID"
        ) b
        GROUP BY b."Studie_ID"
    ) c ON "tblStudies"."Studie_ID" = c."Studie_ID"
4

1 回答 1

1

因为您正在对内联查询“C”进行 LEFT JOIN,所以某些值c."stalen_gebruikt"可以为空。任何数字 - null 都会产生 null。为了解决这个问题,我们可以使用 coalesce

所以改变

"samplesweggezet" - c."stalen_gebruikt" AS "Stock

"samplesweggezet" - COALESCE(c."stalen_gebruikt",0) AS "Stock

于 2013-03-13T15:13:44.977 回答