2013-06-03 129 views
1

在此先感谢您阅读本文,我无法找到解决我的问题的答案......我不明白我所做的与教程/建议不同发现:PHP PDO :: lastInsertId()返回0

SQL表

CREATE TABLE IF NOT EXISTS `LastInsertID` (
    `id` int(11) NOT NULL AUTO_INCREMENT, 
    `name` char(150) NOT NULL, 
    `email` varchar(255) NOT NULL, 
    PRIMARY KEY (`id`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=6 ; 

PHP文件

<?php 

// Connect to database 
$user = "foo"; 
$pswd = "bar"; 

$db = new PDO('mysql:host=localhost;dbname=test', $user, $pswd); 
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); 

// Prepare request 
$rq = $db->prepare('INSERT INTO `LastInsertID` VALUES(NULL,:name,:email)'); 

// Begin and commit request 
$db->beginTransaction(); 
$values = array('name'=>'Foo','email'=>'[email protected]'); 
$rq->execute($values); 
$db->commit(); 

// Echo last ID 
echo $db->lastInsertId(); 

?> 

这种再当它应该返回时变为0.问题在哪里?

+1

http://www.php.net/manual/en/pdo.lastinsertid.php#85129 –

+0

@Pekka웃愚蠢的我,我没有代码示例... – Sheljohn

回答

6

如果您处于事务中,您必须在提交之前使用$db->lastInsertId()。即使你回滚一个事务,这个id也是“被使用”或跳过了,这就是为什么你不应该依赖ID来连续的原因。

+0

谢谢;这会返回正确的ID :)但是如果我在不提交的情况下在不同的表中执行多个准备好的请求,会在每次请求后正确更新吗? – Sheljohn

+0

是的,你可以做很多查询,并获得交易中的每个ID。 – Mike

+0

非常感谢您的帮助!我会标记你作为答案,因此让我:) – Sheljohn

0

使用此

INSERT INTO `LastInsertID` (name, email) VALUES(:name,:email) 

代替

INSERT INTO `LastInsertID` VALUES(NULL,:name,:email) 

我已经删除了NULL

+1

不前阅读句子改变行为 –

+0

@Pekka웃好的我在这里有疑问。如果对于唯一的'Id'和自动增量设置为'NULL'不会影响? – Yogus

+0

如果指定NULL,自动增量将填充正确的值。 (你提出的方式也没有错 - 它不能解决OP的问题,这与提交有关,请参阅Mike的回答) –