"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Comment insérer ou mettre à jour efficacement les lignes en fonction de deux conditions dans MySQL?

Comment insérer ou mettre à jour efficacement les lignes en fonction de deux conditions dans MySQL?

Publié le 2025-06-14
Parcourir:534

How Can I Efficiently INSERT or UPDATE a MySQL Row Based on Two Conditions?

insérer ou mettre à jour avec deux conditions

Description du problème:

L'utilisateur rencontre un défi de concours de temps: insérer une nouvelle ligne dans une table s'il n'y a pas déjà de ligne correspondant à deux conditions spécifiques ('nomme' ',' Dates), s'il n'y a pas déjà de ligne correspondant à deux conditions spécifiques ('' '' '' Dates ' La ligne existante si une correspondance est trouvée.

solution:

La réponse réside dans l'insert de MySQL dans ... sur la syntaxe de mise à jour de la clé en double. Cette fonctionnalité puissante permet une manipulation efficace des données en insérant une nouvelle ligne si aucune ligne correspondante n'existe ou à la mise à jour de la ligne existante si une contrainte de clé unique est violée.

pour réaliser le comportement souhaité, le tableau doit avoir une clé unique définie (une clé composite dans ce cas) pour les deux colonnes («nom» et «dates»). Cette clé sert d'identificateur pour les lignes uniques dans la table.

Exemple de scénario:

Considérez la structure de table suivante:

create table myThing (
    id int auto_increment primary key,
    name int not null,
    values1 int not null,
    values2 int not null,
    dates date not null,
    unique key(name,dates) -- This line is crucial
);

Insertion d'une nouvelle ligne avec l'instruction suivante créera soit une nouvelle ligne ou mettra à jour une nouvelle, selon l'existence d'une ligne avec le même `` nom '' et «dates»:

insert myThing(name,values1,values2,dates) values (777,1,1,'2015-07-11') on duplicate key update values2=values2 1;

Exemple de résultat:

select * from myThing;
 ---- ------ --------- --------- ------------ 
| id | name | values1 | values2 | dates      |
 ---- ------ --------- --------- ------------ 
| 1 | 777 | 1 | 4 | 2015-07-11 |
| 2 | 778 | 1 | 1 | 2015-07-11 |
 ---- ------ --------- --------- ------------ 

Comme l'exemple le démontre, l'insert dans ... sur la syntax de mise à jour de la clé en double gère efficacement les opérations d'insertion et de mise à jour en fonction de la touche unique définie, éliminant le besoin de procédures stockées complexes.

Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3