Heim >Datenbank >MySQL-Tutorial >Wie rufe ich den aktualisierten Wert nach einem MySQL-UPDATE-Vorgang ab?
Aktualisierten Wert von MySQL abrufen
Beim Durchführen eines Aktualisierungsvorgangs in MySQL wird normalerweise standardmäßig die Anzahl der betroffenen Zeilen zurückgegeben. Es gibt jedoch Szenarien, in denen es wünschenswert ist, stattdessen den aktualisierten Wert abzurufen.
Betrachten Sie die folgende Abfrage:
UPDATE item SET `score`=`score`+1 WHERE `id`=1
Diese Abfrage erhöht die Punktzahl eines Elements mit der angegebenen ID. Standardmäßig wäre das Ergebnis der Ausführung dieser Abfrage die Anzahl der betroffenen Zeilen, in diesem Fall 1.
Um den aktualisierten Wert abzurufen, kann jedoch eine gespeicherte Prozedur verwendet werden. Mit einer gespeicherten Prozedur können Sie eine Reihe von SQL-Anweisungen als einzelne Einheit ausführen und können wie folgt definiert werden:
<code class="sql">DELIMITER $$ -- Change DELIMITER in order to use ; withn the procedure CREATE PROCEDURE increment_score ( IN id_in INT ) BEGIN UPDATE item SET score = score + 1 WHERE id = id_in; SELECT score AS new_score FROM item WHERE id = id_in; END $$ -- Finish CREATE PROCEDURE statement DELIMITER ; -- Reset DELIMITER to standard ;</code>
Diese gespeicherte Prozedur aktualisiert zunächst den Score und wählt dann den neuen Wert in einem Ausgabeparameter mit dem Namen aus new_score. In PHP können Sie diese gespeicherte Prozedur aufrufen und den aktualisierten Wert wie folgt abrufen:
<code class="php">$result = mysql_query("CALL increment_score($id)"); $row = mysql_fetch_array($result); echo $row['new_score'];</code>
Durch die Verwendung einer gespeicherten Prozedur können Sie sowohl die Aktualisierungs- als auch die Abrufvorgänge innerhalb einer einzigen Abfrage ausführen und so die Anzahl reduzieren Abfragen und Verbesserung der Leistung.
Das obige ist der detaillierte Inhalt vonWie rufe ich den aktualisierten Wert nach einem MySQL-UPDATE-Vorgang ab?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!