Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

Query efficiente per trovare record duplicati

In genere, eseguiresti un self join alla stessa tabella e inseriresti i tuoi criteri di "duplicazione" nelle condizioni di join.

Es.

SELECT
    *
FROM
    Transactions t1
        inner join
    Transactions t2
        on
            t1.Terminal = t2.Terminal and
            t1.Amount = t2.Amount and
            DATEDIFF(minute,t2.TransactionDate,t1.TransactionDate) between 0 and 10 and
            t1.TransactionID > t2.TransactionID /* prevent matching the same row */