下面俩个表如何合并,但不是in ner j oin。就是年月日一致的行,在同一行。仅有发货或者仅有收获的,单独保留一行。
data:image/s3,"s3://crabby-images/1f46a/1f46a0aea84bf649da14426cb5f1882829f75aa4" alt="dvubb"
此主题相关图片如下:捕获.png
data:image/s3,"s3://crabby-images/6cef8/6cef8fbc958aa46e7a1c0b2b9197a28c19d00ce9" alt="dvubb 按此在新窗口浏览图片"
能否通过sql语句实现?我现在是用代码实现的。有点慢
什么数据库?un寄库和de出库时间有没有时分秒值?
[此贴子已经被作者于2024/2/4 10:36:08编辑过]
都是sql,都是日期列,没有时分秒。但是不排除可能,所以用了datepart。
到数据库里建2个视图视图1
select un寄库,unfamily,sum(盒数) as 盒数 from (select CONVERT(nvarchar(10), un寄库, 120 ) As un寄库,unfamily ,盒数,dateDiff(month,un寄库,getdate()) as 月数 from 成品数据 ) as a where 月数 < 3 group by un寄库,unfamily
视图2
select de出库时间,unfamily,sum(de发货数量) as 出货盒数 from (select CONVERT(nvarchar(10), de出库时间, 120 ) As de出库时间,unfamily ,de发货数量,dateDiff(month,de出库时间,getdate()) as 月数 from 发货记录 ) as a where 月数 < 3 group by de出库时间,unfamily
然后使用sql生成表格
select year(a.un寄库) as 年,month(a.un寄库) as 月,day(a.un寄库) as 日,盒数,出货盒数,a.unfamily,b.unfamily as 出库unfamily from 视图1 as a inner join 视图2 as b on a.un寄库 = b.de出库时间
union all
select year(un寄库) as 年,month(un寄库) as 月,day(un寄库) as 日,盒数,0 as 出货盒数,unfamily,'' as 出库unfamily from 视图1 where un寄库 not in (select de出库时间 from 视图2)
union all
select year(de出库时间) as 年,month(de出库时间) as 月,day(de出库时间) as 日,0 as 盒数,出货盒数,'' as unfamily,unfamily as 出库unfamily from 视图2 where de出库时间 not in (select un寄库 from 视图1)
[此贴子已经被作者于2024/2/4 11:09:19编辑过]