3

我正在尝试mysql_insert_id使用 PDO。到目前为止,我还没有找到一个适用于插入和更新的好例子。有没有人有一段完整的代码作为例子?

4

3 回答 3

8

如果您需要 $pdo->lastInsertId()返回刚刚更新的行的 id(如果需要,我会认真重新考虑我的设计,但是嘿……可能是真正的需要),请像这样进行更新:

 UPDATE tablename  SET some_column='somevalue',id=LAST_INSERT_ID(id);
于 2012-06-19T18:03:21.337 回答
3

PDO::lastInsertId。返回最后插入的行或序列值的 ID

于 2012-06-19T18:00:28.157 回答
0
<?php 
try { 
    $dbh = new PDO('mysql:host=localhost;dbname=test', 'usrname', 'passwrd'); 

    $stmt = $dbh->prepare("INSERT INTO test (name, email) VALUES(?,?);"); 

    try { 
        $dbh->beginTransaction(); 
        $stmt->execute( array('user', 'user@example.com')); 
        $dbh->commit(); 
        print $dbh->lastInsertId(); 
    } catch(PDOExecption $e) { 
        $dbh->rollback(); 
        print "Error!: " . $e->getMessage() . "</br>"; 
    } 
} catch(PDOExecption $e) { 
    print "Error!: " . $e->getMessage() . "</br>"; 
} 
?>
于 2012-06-19T18:04:11.890 回答