PDO 获取最后插入的 ID

2022-08-30 06:28:30

我有一个查询,我想获取插入的最后一个 ID。字段 ID 是主键,并且会自动递增。

我知道我必须使用这个语句:

LAST_INSERT_ID()

该语句适用于如下查询:

$query = "INSERT INTO `cell-place` (ID) VALUES (LAST_INSERT_ID())";

但是,如果我想使用此语句获取ID:

$ID = LAST_INSERT_ID();

我收到此错误:

Fatal error: Call to undefined function LAST_INSERT_ID()

我做错了什么?


答案 1

那是因为这是一个SQL函数,而不是PHP。您可以使用 PDO::lastInsertId()

喜欢:

$stmt = $db->prepare("...");
$stmt->execute();
$id = $db->lastInsertId();

如果你想用SQL而不是PDO API来做,你可以像普通的选择查询一样去做:

$stmt = $db->query("SELECT LAST_INSERT_ID()");
$lastId = $stmt->fetchColumn();

答案 2

lastInsertId() 仅在 INSERT 查询之后工作。

正确:

$stmt = $this->conn->prepare("INSERT INTO users(userName,userEmail,userPass) 
                              VALUES(?,?,?);");
$sonuc = $stmt->execute([$username,$email,$pass]);
$LAST_ID = $this->conn->lastInsertId();

不對:

$stmt = $this->conn->prepare("SELECT * FROM users");
$sonuc = $stmt->execute();
$LAST_ID = $this->conn->lastInsertId(); //always return string(1)=0

推荐