sql >> Database teknologi >  >> Database Tools >> SSMS

Hvordan henter man data fra SQL Server baseret på nedenstående eksempel?

Måske kan du bruge en løsning som nedenforSe fungerende demo

declare @d date='2018-Jun-03'

; with Indexer as 
(
    select 
        *, 
        rn= row_number() over(partition by CustName order by RecordedTime),
        rn2=row_number() over(partition by CustName order by RecordedTime desc)
    from records
)
,GetValidCustomerRecords as
(
    select 
        CustName,
        Country,
        RecordedTime,
        Audit   = case when cast(RecordedTime as date)[email protected] and rn=1 then 'add' else 'change' end,
        History = case 
                    when cast(RecordedTime as date)[email protected] and rn=1 
                    then 'new' 
                    when cast(RecordedTime as date)<@d and rn=1 
                    then 'before'
                    else 'current' end
    from Indexer i 
    where CustName in
    (
    select 
        distinct CustName 
    from records
    where cast(RecordedTime as date)[email protected]
    ) 
    and (rn=1 or rn2=1) and cast(RecordedTime as date)<[email protected]
)

select * from GetValidCustomerRecords
order by CustName, RecordedTime



  1. phpMyAdmin-konfigurationslagringsfejl

  2. DELETE FROM-sætning virker ikke

  3. SQL Database Migration med SSMS

  4. phpMyAdmin kan ikke oprette forbindelse til MySQL-serveren