"Se um trabalhador quiser fazer bem o seu trabalho, ele deve primeiro afiar suas ferramentas." - Confúcio, "Os Analectos de Confúcio. Lu Linggong"
Primeira página > Programação > Como recuperar a data de login mais recente para cada usuário no SQL?

Como recuperar a data de login mais recente para cada usuário no SQL?

Postado em 2025-02-06
Navegar:868

How to Retrieve the Latest Login Date for Each User in SQL?

consulta SQL para a última data de registro de login para cada usuário

pergunta:

Suponha que a tabela de banco de dados contenha informações de login do usuário, como recuperarmos a última data de login para cada usuário? Considerando que pode haver datas de login duplicadas.

Solução:

Existem duas maneiras comuns de resolver esse problema:

Método 1: Subquery usando inner Junção

Este método usa uma subconsulta para identificar a última data de login para cada usuário e é usada para filtrar a tabela principal:

select t.username, t.date, t.value
from MyTable t
inner join (
    select username, max(date) as MaxDate
    from MyTable
    group by username
) tm on t.username = tm.username and t.date = tm.MaxDate

Método 2: função da janela

]

Para bancos de dados que suportam funções da janela, um método mais eficiente pode ser usado:

select x.username, x.date, x.value 
from (
    select username, date, value,
        row_number() over (partition by username order by date desc) as _rn
    from MyTable 
) x
where x._rn = 1

Este método usa números de linha classificando os dados da partição, onde a última data de cada usuário recebe um nível 1.

Tutorial mais recente Mais>

Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.

Copyright© 2022 湘ICP备2022001581号-3