简体   繁体   English

如何在SQL查询结果中动态添加行

[英]How to dynamically add row(s) in SQL query result

this query 这个查询

SELECT T.TestTypeId, F.FlockCode, AMT, CV, S.SampleDate 
FROM [dbo].[Tests] AS T 
JOIN [Samples] AS S ON T.SampleId = S.Id 
JOIN [TestTypes] AS TT ON T.TestTypeId = TT.Id 
JOIN [Flocks] AS F ON T.FlockId = F.Id 
WHERE T.TestTypeId = 7 AND T.IsDeleted = 0 
AND S.SampleDate BETWEEN '2017-12-17' AND '2018-01-08' 
AND T.FlockId IN (7,13)
ORDER BY S.SampleDate, F.FlockCode

returns the following result 返回以下结果

TestTypeId  FlockCode   AMT     CV      SampleDate
7           R1.33       8.93    9.28    2017-12-17
7           R1.33       9.05    10.76   2018-01-01
7           R1.37       8.95    8.99    2018-01-01

which is accurate for the existing data, where for S.SampleDate 2017-12-17 there is only one row for FlockCode R1.33. 这是准确的现有的数据,其中对于S.SampleDate 2017年12月17日,只有一个用于行FlockCode R1.33。

Now I need, to add another row in this result for the FlockCode R1.37 on the data 2017-12-17 with 0 or null AMT & CV value. 现在我需要在数据2017-12-17上为FlockCode R1.37添加另一行,其中0或者为null AMTCV值。

So the expected result would be 所以预期的结果是

TestTypeId  FlockCode   AMT     CV      SampleDate
7           R1.33       8.93    9.28    2017-12-17
7           R1.37       0       0       2017-12-17
7           R1.33       9.05    10.76   2018-01-01
7           R1.37       8.95    8.99    2018-01-01

Any solution in either SQL or LINQ or C# will be very helpful. SQLLINQC#任何解决方案都将非常有用。 Thanks in advance. 提前致谢。

The basic structure is to do this with a cross join and left join . 基本结构是使用cross joinleft join来完成此操作。 Your query is a bit complicated, so I would suggest: 您的查询有点复杂,所以我建议:

with t as (
      SELECT T.TestTypeId, F.FlockCode, AMT, CV, S.SampleDate 
      FROM [dbo].[Tests] T JOIN
           [Samples] S
           ON T.SampleId = S.Id JOIN
           [TestTypes] TT
           ON T.TestTypeId = TT.Id  JOIN
           [Flocks] F
           ON T.FlockId = F.Id 
      WHERE T.TestTypeId = 7 AND T.IsDeleted = 0 AND
            S.SampleDate BETWEEN '2017-12-17' AND '2018-01-08' AND
            T.FlockId IN (7, 13)
     )
SELECT f.TestTypeId, f.FlockCode, COALESCE(t.AMT, 0) as AMT,
       COALESCE(t.CV, 0) as CV, d.SampleDate
FROM (SELECT DISTINCT TestTypeId, FlockCode FROM t) f CROSS JOIN
     (SELECT DISTINCT SampleDate FROM t) d LEFT JOIN
     t
     ON f.FlockCode = t.FlockCode AND f.TestTypeId = t.TestTypeId,
        d.SampleDate = t.SampleDate
ORDER BY d.SampleDate, f.FlockCode;

In SQL you could use UNION operator SQL中,您可以使用UNION运算符

SELECT T.TestTypeId, F.FlockCode, AMT, CV, S.SampleDate 
FROM [dbo].[Tests] AS T 
JOIN [Samples] AS S ON T.SampleId = S.Id 
JOIN [TestTypes] AS TT ON T.TestTypeId = TT.Id 
JOIN [Flocks] AS F ON T.FlockId = F.Id 
WHERE T.TestTypeId = 7 AND T.IsDeleted = 0 
AND S.SampleDate BETWEEN '2017-12-17' AND '2018-01-08' 
AND T.FlockId IN (7,13)
UNION 
SELECT 7 AS TestTypeId, 'R1.37' AS FlockCode, 0 AS AMT, 0 AS CV, '2017-12-17' AS SampleDate
ORDER BY SampleDate, FlockCode

Just UNION it! 只是UNION吧!

SELECT T.TestTypeId, F.FlockCode, AMT, CV, S.SampleDate 
FROM [dbo].[Tests] AS T 
JOIN [Samples] AS S ON T.SampleId = S.Id 
JOIN [TestTypes] AS TT ON T.TestTypeId = TT.Id 
JOIN [Flocks] AS F ON T.FlockId = F.Id 
WHERE T.TestTypeId = 7 AND T.IsDeleted = 0 
AND S.SampleDate BETWEEN '2017-12-17' AND '2018-01-08' 
AND T.FlockId IN (7,13)
UNION
SELECT 7 AS TestTypeId, 'R1.37' as FlockCode, 0 as AMT, 0 as CV, '2017-12-17' as SampleDate
ORDER BY SampleDate, FlockCode

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM