"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 classificar os clientes no MySQL usando variáveis ​​e funções de janela?

Como classificar os clientes no MySQL usando variáveis ​​e funções de janela?

Postado em 2025-02-06
Navegar:223

How to Rank Customers in MySQL Using Variables and Window Functions?

explicação detalhada do método de classificação do cliente MySQL

]

atribuindo classificações com base em critérios específicos é uma tarefa comum ao processar dados do cliente. O MySQL fornece várias maneiras de atingir esse objetivo.

Um método é usar variáveis ​​de classificação, conforme mostrado na seguinte consulta:

SELECT    first_name,
          age,
          gender,
          @curRank := @curRank   1 AS rank
FROM      person p, (SELECT @curRank := 0) r
ORDER BY  age;

aqui, a variável @currank é inicializada para 0 e é incrementada para cada linha na tabela. Isso nos permite atribuir classificações com base na idade de nossos clientes.

Outra maneira é usar a função row_number (), que retorna um número de pedido exclusivo para cada linha na partição. A consulta a seguir demonstra seu uso:

SELECT    first_name,
          age,
          gender,
          ROW_NUMBER() OVER (PARTITION BY gender ORDER BY age) AS rank
FROM      person;

Nesta consulta, a função row_number () atribui classificações em cada partição de gênero, permitindo classificar os clientes com base na idade de cada sexo.

Finalmente, a função dense_rank () pode ser usada para atribuir rankings sem gap. Ele pula rankings que teriam sido atribuídos para duplicar valores. A consulta a seguir demonstra seu uso:

SELECT    first_name,
          age,
          gender,
          DENSE_RANK() OVER (PARTITION BY gender ORDER BY age) AS rank
FROM      person;

selecionando a função de classificação apropriada, os desenvolvedores podem atribuir efetivamente classificações aos dados do cliente no MySQL para vários fins analíticos.

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