|
Publicité | ||||||||||||||||||||||
|
|
#1 | ||
|
Membre du Club
![]() Inscription : avril 2006 Messages : 205 ![]() |
Bonjour,
Voici mon problème: -je voudrai faire un UPDATE si l'élément existe en DB, sinon un INSERT. Pré-requis: ne pas faire de procédure stockée. A noter que je ne peux identifier mon élément par la clé primaire ou un index unique. ( donc pas de "REPLACE" ou "insert ... on duplicate key" possible à ma connaissance. Merki :p CODE avec une procédure stockée qui peut peut être illustrer le problème: Code :
__________________
La différence entre la théorie et la pratique, c'est qu'en théorie, il n'y a pas de différence, mais qu'en pratique, il y en a une. Dernière modification par SrK ; 08/03/2010 à 15h52. |
||
|
|
00
|
|
|
#2 |
![]() ![]() Cédric DuprezInscription : avril 2002 Messages : 3 778 ![]() |
Bonjour,
MySQL dispose de cette possibilité nativement, dans la syntaxe INSERT, avec la clause ON DUPLICATED KEY UPDATE... Plus d'infos dans la documentation de MySQL : http://dev.mysql.com/doc/refman/5.0/fr/insert.html ced
__________________
Rédacteur / Modérateur SGBD Mes tutoriels et la FAQ MySQL ---------------------------------------------------- Pensez aux balises code et au tag Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça
|
|
|
00
|
|
|
#3 |
|
Membre du Club
![]() Inscription : avril 2006 Messages : 205 ![]() |
Merci, mais comme indiqué dans mon message, je ne crois pas pouvoir faire de "insert ... on duplicate key" sachant que je n'ai pas la possibilité d'identifier mon élément par "une clé primaire" ou un "index unique", qui semble des pré-requis à l'utilisation de "insert ... on duplicate key" si je ne me trompe pas.
__________________
La différence entre la théorie et la pratique, c'est qu'en théorie, il n'y a pas de différence, mais qu'en pratique, il y en a une. |
|
|
00
|
|
|
#4 |
![]() ![]() Cédric DuprezInscription : avril 2002 Messages : 3 778 ![]() |
Au temps pour moi, j'ai laissé passé ce "détail".
Du coup, en SQL, ce n'est pas possible. Si tu ne veux pas de procédure, et si tu n'as pas de clé, alors il n'existe aucune instruction qui puisse te permettre de choisir entre un update et un insert selon le cas... En tout cas, pas à ma connaissance... ced
__________________
Rédacteur / Modérateur SGBD Mes tutoriels et la FAQ MySQL ---------------------------------------------------- Pensez aux balises code et au tag Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça
|
|
|
00
|
Copyright © 2000-2012 - www.developpez.com