Heim >Datenbank >MySQL-Tutorial >Wie kann ich mit PHP die ID der zuletzt aktualisierten Zeile in MySQL abrufen?

Wie kann ich mit PHP die ID der zuletzt aktualisierten Zeile in MySQL abrufen?

Linda Hamilton
Linda HamiltonOriginal
2024-12-17 09:21:24986Durchsuche

How to Retrieve the ID of the Last Updated Row in MySQL using PHP?

Abrufen der ID der zuletzt aktualisierten Zeile in MySQL mit PHP

Das Ermitteln der ID der zuletzt aktualisierten Zeile in einer MySQL-Datenbank ist ein häufiges Bedürfnis in der Programmierung.

Wie man diese Aufgabe erledigt PHP:

Um die ID der letzten in MySQL geänderten Zeile über PHP zu erhalten, verwenden Sie das bereitgestellte PHP-Skript:

<?php
// Establish database connection
$conn = new mysqli("host", "username", "password", "database_name");

// Prepare the MySQL UPDATE statement with an auto-incrementing variable
$sql = "SET @update_id := 0;
        UPDATE some_table SET column_name = 'value', id = (SELECT @update_id := id)
        WHERE some_other_column = 'value' LIMIT 1;";

if ($conn->query($sql) === TRUE) {
    // Get the last updated row's ID
    $result = $conn->query("SELECT @update_id;");
    $id = $result->fetch_assoc()["@update_id"];
    echo "Last updated row's ID: $id";
} else {
    echo "Error updating row: " . $conn->error;
}

$conn->close();
?>

Zusätzliche Überlegungen:

  • Achtung: Diese Methode sollte mit Vorsicht angewendet werden, da sie eine bestimmte Spalte erfordert automatisch inkrementiert.
  • Erweitern der Technik:Sie können dies ändern, um alle betroffenen Zeilen-IDs abzurufen, indem Sie einen ähnlichen Ansatz mit der CONCAT_WS-Funktion verwenden.

Für Beispielsweise gibt der folgende Code eine durch Kommas getrennte Zeichenfolge aller aktualisierten Zeilen-IDs zurück:

SET @uids := null;
UPDATE footable
   SET foo = 'bar'
 WHERE fooid > 5
   AND ( SELECT @uids := CONCAT_WS(',', fooid, @uids) );
SELECT @uids;

Das obige ist der detaillierte Inhalt vonWie kann ich mit PHP die ID der zuletzt aktualisierten Zeile in MySQL abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn