Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

Consulta eficiente para encontrar registros duplicados


Geralmente, você faria uma autojunção na mesma tabela e colocaria seus critérios "duplicados" nas condições de junção.

Por exemplo.
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 */