Mysql : ON DUPLICATE KEY UPDATE

Laisser une réponse »

Une petite clause bien pratique : ON DUPLICATE KEY UPDATE.
Imaginez que vous vouliez mettre à jour un enregistrement dans votre base dans le cas ou celui ci existe déjà et sinon, s’il n’existe pas, en créer un nouveau. Une solution serait de faire un SELECT sur la clé, et soit un UPDATE ou un INSERT selon que la clé existe ou non. Une autre solution serait de faire un UPDATE et si mysql_affected_rows == 0 alors vous faites un INSERT… Pourquoi pas.

Mais MySQL permet de faire tout ça en une seule requête !
[cc lang=’php’ width=’100%’]
INSERT INTO maTable (id_table,champ_table)
VALUES (‘152′,’valeur à modifier’)
ON DUPLICATE KEY UPDATE
champ_table=’valeur à modifier’;
[/cc]
Bien entendu, pas besoin de mettre de WHERE dans la partie UPDATE vu que c’est parce que la clé existe que le update est exécuté

A noter que ON DUPLICATE KEY UPDATE est différent de REPLACE qui s’apparente plutôt à un DELETE + INSERT qui oblige à donner une valeur à tous les champs, alors qu’avec ON DUPLICATE KEY UPDATE on ne spécifie que les champs qui sont à modifier.



ShareThis

Publicité

Laisser un commentaire

Version bureau | Passer à la version mobile