"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 atualizar linhas e obter IDs atualizados no MySQL sem uma subconsulta?

Como atualizar linhas e obter IDs atualizados no MySQL sem uma subconsulta?

Publicado em 2024-11-08
Navegar:261

How to Update Rows and Get Updated IDs in MySQL Without a Subquery?

Combinando consultas SELECT e UPDATE no MySQL

Combinar consultas SELECT e UPDATE em uma única operação pode ser útil para otimizar o desempenho do banco de dados. Neste caso, um usuário deseja combinar as seguintes consultas:

SELECT * FROM table WHERE group_id = 1013 and time > 100;
UPDATE table SET time = 0 WHERE group_id = 1013 and time > 100

Embora uma abordagem de subconsulta possa não fornecer os resultados desejados, existe uma solução que pode atingir o objetivo sem uma subconsulta. Esta solução envolve o uso de uma variável definida pelo usuário (@uids) para armazenar os IDs de linha atualizados:

UPDATE footable
   SET foo = 'bar'
 WHERE fooid > 5
   AND ( SELECT @uids := CONCAT_WS(',', fooid, @uids) );
SELECT @uids;```
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