Obtener ID del último registro insertado
Si realizamos un INSERT o UPDATE en una tabla con un campo AUTO_INCREMENT, podemos obtener el ID del último registro insertado / modificada inmediatamente.
En la tabla de "MyGuests" , el "id" columna es un campo AUTO_INCREMENT:
CREATE TABLE MyGuests (
id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
firstname VARCHAR(30) NOT NULL,
lastname VARCHAR(30) NOT NULL,
email VARCHAR(50),
reg_date TIMESTAMP
)
Los siguientes ejemplos son iguales a los ejemplos de la página anterior ( PHP insertar datos en MySQL ), excepto que hemos añadido una sola línea de código para recuperar el ID del último registro insertado. También nos hacemos eco del último registro insertado ID:
Ejemplo (MySQLi Object-oriented)
<?php
$servername = "localhost";
$username = "username";
$password =
"password";
$dbname =
"myDB";
// Create connection
$conn =
new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
$sql = "INSERT INTO
MyGuests (firstname, lastname, email)
VALUES ('John', 'Doe', '[email protected]')";
if ($conn->query($sql) === TRUE) {
$last_id =
$conn->insert_id;
echo "New record created successfully. Last
inserted ID is: " . $last_id;
} else {
echo
"Error: " . $sql . "<br>" . $conn->error;
}
$conn->close();
?>
Ejemplo (MySQLi Procedural)
<?php
$servername = "localhost";
$username = "username";
$password =
"password";
$dbname =
"myDB";
// Create connection
$conn = mysqli_connect($servername, $username, $password,
$dbname);
// Check connection
if (!$conn) {
die("Connection
failed: " . mysqli_connect_error());
}
$sql = "INSERT INTO
MyGuests (firstname, lastname, email)
VALUES ('John', 'Doe', '[email protected]')";
if (mysqli_query($conn, $sql)) {
$last_id =
mysqli_insert_id($conn);
echo "New record created
successfully. Last inserted ID is: " . $last_id;
} else {
echo "Error: "
. $sql . "<br>" . mysqli_error($conn);
}
mysqli_close($conn);
?>
Ejemplo (PDO)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname =
"myDBPDO";
try {
$conn = new PDO("mysql:host=$servername;dbname=$dbname",
$username, $password);
// set the PDO error mode to exception
$conn->setAttribute(PDO::ATTR_ERRMODE,
PDO::ERRMODE_EXCEPTION);
$sql = "INSERT INTO
MyGuests (firstname, lastname, email)
VALUES ('John', 'Doe', '[email protected]')";
// use exec() because no
results are returned
$conn->exec($sql);
$last_id = $conn->lastInsertId();
echo "New record
created successfully. Last inserted ID is: " . $last_id;
}
catch(PDOException $e)
{
echo $sql . "<br>" . $e->getMessage();
}
$conn = null;
?>