Mettre à jour efficacement plusieurs tables MySQL en une seule fois
La pratique standard des bases de données implique souvent des requêtes de mise à jour distinctes pour chaque table. Cependant, MySQL propose une méthode simplifiée pour mettre à jour plusieurs tables simultanément à l'aide d'une seule requête. Cette approche simplifie les interactions avec la base de données, améliore la clarté du code et peut potentiellement améliorer les performances en réduisant la surcharge de communication avec la base de données.
La technique de mise à jour à requête unique
La syntaxe suivante montre comment mettre à jour plusieurs tables MySQL avec une seule requête :
<code class="language-sql">UPDATE TABLE1, TABLE2 SET TABLE1.column1 = value1, TABLE1.column2 = value2, TABLE2.column1 = value1, TABLE2.column2 = value2 WHERE condition;</code>
Illustrons cela avec un exemple impliquant deux tables : Books
et Orders
.
<code class="language-sql">-- Books table CREATE TABLE Books ( BookID INT PRIMARY KEY, BookName VARCHAR(50), InStock INT ); -- Orders table CREATE TABLE Orders ( OrderID INT PRIMARY KEY, BookID INT, Quantity INT );</code>
Supposons que nous devions augmenter la quantité commandée de OrderID
1002 de 2 et simultanément diminuer le stock de livres dans le tableau Books
. La requête suivante y parvient :
<code class="language-sql">UPDATE Books, Orders SET Orders.Quantity = Orders.Quantity + 2, Books.InStock = Books.InStock - 2 WHERE Books.BookID = Orders.BookID AND Orders.OrderID = 1002;</code>
Cette méthode rationalise les opérations de la base de données, rendant votre code plus lisible et potentiellement plus rapide en réduisant le nombre d'interactions avec la base de données.
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!