[英]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
AMT
和CV
值。
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. SQL
或LINQ
或C#
任何解决方案都将非常有用。 Thanks in advance. 提前致谢。
The basic structure is to do this with a cross join
and left join
. 基本结构是使用
cross join
和left 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.