Maison > base de données > tutoriel mysql > Comment effectuer une mise à jour multi-tables (JOIN UPDATE) dans MySQL ?

Comment effectuer une mise à jour multi-tables (JOIN UPDATE) dans MySQL ?

DDD
Libérer: 2025-01-05 06:59:43
original
827 Les gens l'ont consulté

How to Perform a Multi-Table Update (JOIN UPDATE) in MySQL?

Syntaxe MySQL pour la mise à jour de jointure

Dans MySQL, une mise à jour multi-tables est possible avec une syntaxe spécifique. Cette syntaxe permet la mise à jour de plusieurs tables, en fonction d'une condition de jointure.

Mise en œuvre d'une mise à jour de jointure

Considérez le scénario suivant : vous souhaitez incrémenter la capacité d'un train lorsque une réservation est annulée. Pour y parvenir, vous pouvez utiliser une requête de mise à jour de jointure comme suit :

UPDATE Reservations r
JOIN Train t ON (r.Train = t.TrainID)
SET t.Capacity = t.Capacity + r.NoSeats
WHERE r.ReservationID = ?;
Copier après la connexion

où "?" représente l'ID de réservation associé à la réservation annulée.

Incrémentation d'un nombre arbitraire

La requête ci-dessus peut être modifiée pour incrémenter la capacité d'un nombre arbitraire de sièges :

UPDATE Reservations r
JOIN Train t ON (r.Train = t.TrainID)
SET t.Capacity = t.Capacity + <arbitrary_number>
WHERE r.ReservationID = ?;
Copier après la connexion

Comportement de transaction

Lors de l'augmentation de la capacité du train et pour supprimer la réservation en une seule transaction, il est crucial de suivre un ordre précis. Tant que vous mettez à jour la table Train avant de la supprimer de la table Réservations, la transaction conservera son intégrité.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal