Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

Requête efficace pour trouver des enregistrements en double

En règle générale, vous effectuez une auto-jointure sur la même table et placez vos critères de "duplication" dans les conditions de jointure.

Par exemple

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 */