"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 realizar atualizações condicionais no INSERT ... ON DUPLICATE KEY UPDATE do MySQL?

Como realizar atualizações condicionais no INSERT ... ON DUPLICATE KEY UPDATE do MySQL?

Publicado em 17/11/2024
Navegar:451

How to Perform Conditional Updates in MySQL\'s INSERT ... ON DUPLICATE KEY UPDATE?

Atualização condicional em INSERT ... ON DUPLICATE KEY UPDATE

No MySQL, a sintaxe INSERT ... ON DUPLICATE KEY UPDATE permite atualização automática dos dados da tabela quando uma chave duplicada é encontrada durante uma operação de inserção. No entanto, a parte UPDATE da consulta não suporta o uso de uma cláusula WHERE para especificar atualizações condicionais.

Solução alternativa usando IF()

Para superar essa limitação, pode-se utilizar a função IF() para implementar atualizações condicionais dentro da cláusula ON DUPLICATE KEY UPDATE. A função IF() avalia uma condição e retorna um valor diferente com base no resultado.

Por exemplo, considere a seguinte instrução INSERT ... ON DUPLICATE KEY UPDATE:

INSERT INTO daily_events (created_on, last_event_id, last_event_created_at)
VALUES ('2010-01-19', 23, '2010-01-19 10:23:11')
ON DUPLICATE KEY UPDATE
  last_event_id = IF(last_event_created_at 

Nesta instrução, a função IF() verifica se o valor da coluna last_event_created_at na tabela do banco de dados é menor que o valor sendo inserido (VALUES(last_event_created_at)). Se for verdade, atualiza a coluna last_event_id com o novo valor da instrução insert. Caso contrário, ele deixa o valor existente inalterado.

Esta solução alternativa permite atualizações condicionais em instruções INSERT ... ON DUPLICATE KEY UPDATE sem recorrer a combinações de consultas INSERT/UPDATE/SELECT, que podem não ser adequadas para replicação cenários.

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