sql server—联合结果的sql逻辑如果表a和表b中的id、日期、时间相同,则使用表b和表b

m2xkgtsf  于 2021-08-01  发布在  Java
关注(0)|答案(1)|浏览(375)

我正在处理一个查询(结果将导出到另一个供应商)我发现我不能在同一个id的同一日期和时间有两个不同的事务类型。如果有冲突,我需要让逻辑从结果b传递id、日期、时间、人工代码、“打卡”类型,并忽略结果a的冲突
当前代码:

select 
    E.idnum, 
    CONVERT(VARCHAR(10), at.DTTMSTAMP, 111) as 'date', 
    at.DTTMSTAMP,
    '',
    '',
    CASE when (select Count (*) from ARCHIVES A1, ARCTRANSACTIONS AT1 where at1.ownerid = a1.UNIQUEID and a1.eventdate =a.EVENTDATE and a1.FILEKEY = a.filekey and at.DTTMSTAMP <= at1.DTTMSTAMP)%2 =0 then 'In Punch' Else 'Out Punch' End as 'Type'  ,
    '' 
from ARCHIVES A, ARCTRANSACTIONS AT, Employees E 
where E.filekey = at.FILEKEY and at.ownerid = a.UNIQUEID and a.eventdate between '2020-06-21' and '2020-06-27'

UNION

select 
    E.IDNUM,
    s.EVENTDATE as 'date',
    s.STARTTIME,
    '/'+WG5.code+'///'+WG4.CODE+'//'+WG6.CODE,
    '',
    'Transfer',
    ''  
from WORKGROUPTRANS S, Employees E, WORKGROUP1 wg1, WORKGROUP2 wg2,WORKGROUP3 wg3, WORKGROUP4 wg4, WORKGROUP5 wg5, WORKGROUP6 wg6  
where EVENTDATE between '2020-06-21' and '2020-06-27' and e.filekey = s.FILEKEY and wg1.WGNUM = s.WG1 and wg2.WGNUM = s.WG2 and wg3.WGNUM = s.WG3 and wg4.WGNUM = s.WG4 and wg5.WGNUM = s.WG5 and wg6.WGNUM = s.WG6

order by 1,2,3,4

57hvy0tb

57hvy0tb1#

这是一个未经测试的查询,可能包含打字错误:

;with a as (
    select 
        E.idnum, 
        CONVERT(VARCHAR(10), at.DTTMSTAMP, 111) as 'date', 
        at.DTTMSTAMP,
        '' Code,
        '' Col1,
        CASE when (select Count (*) from ARCHIVES A1, ARCTRANSACTIONS AT1 where at1.ownerid = a1.UNIQUEID and a1.eventdate =a.EVENTDATE and a1.FILEKEY = a.filekey and at.DTTMSTAMP <= at1.DTTMSTAMP)%2 =0 then 'In Punch' Else 'Out Punch' End as 'Type'  ,
        '' Col2
    from ARCHIVES A, ARCTRANSACTIONS AT, Employees E 
    where E.filekey = at.FILEKEY and at.ownerid = a.UNIQUEID and a.eventdate between '2020-06-21' and '2020-06-27'
),
b as (
    select 
        E.IDNUM,
        s.EVENTDATE as 'date',
        s.STARTTIME,
        '/'+WG5.code+'///'+WG4.CODE+'//'+WG6.CODE as Code,
        '',
        'Transfer' as Type,
        ''  
    from WORKGROUPTRANS S, Employees E, WORKGROUP1 wg1, WORKGROUP2 wg2,WORKGROUP3 wg3, WORKGROUP4 wg4, WORKGROUP5 wg5, WORKGROUP6 wg6  
    where EVENTDATE between '2020-06-21' and '2020-06-27' and e.filekey = s.FILEKEY and wg1.WGNUM = s.WG1 and wg2.WGNUM = s.WG2 and wg3.WGNUM = s.WG3 and wg4.WGNUM = s.WG4 and wg5.WGNUM = s.WG5 and wg6.WGNUM = s.WG6
)
select a.idnum, a.date, a.DTTMSTAMP, 
    isnull(b.Code,'' as )Code, a.Col1, 
    case when b.Type is not null then 'In Punch' else a.Type end as Type, 
    a.Col2
from a
left join b on b.idnum=a.idnum and b.STARTTIME=a.DTTMSTAMP
union
select * from b
where not exists(select * from a where a.idnum=b.idnum and a.DTTMSTAMP=b.STARTTIME)
order by 1,2,3,4

相关问题