正如标题所说,我希望在INSERT之后将行的id返回到数据库。
我有两个功能,一个用于连接数据库:
function db_connect() {
$host = "host";
$user = "user";
$pwd = "pwd";
$database = "db";
$con;
try{
$conn = new PDO( "sqlsrv:Server= ".$host." ; Database = ".$database." ", $user, $pwd);
}
catch(Exception $e){
die(print_r($e));
}
return $conn;
}
还有一个插入新记录:
function setTiptile($name,$cols,$rows) {
$connect = db_connect();
$query = "INSERT INTO data(ID, name, cols, rows) VALUES(NEWID(),?,?,?)";
$stmt = $connect->prepare($query);
$stmt->bindValue(1, $name);
$stmt->bindValue(2, $cols);
$stmt->bindValue(3, $rows);
$stmt->execute();
return $connect->lastInsertId('ID'); // This should work, but doesn't, why?
}
我需要最后一个函数来返回插入行的ID,我应该怎么做?
编辑:正如标题所说,ID是一个唯一的标识符,不知道这是否会改变事情。
编辑:好的,显然我必须使用:$connect->lastInsertId('ID');
,但这根本不会返回任何内容。造成这种情况的原因是什么?在数据库中创建了新行。
来自手册:
返回最后插入的行的ID,或序列对象,具体取决于底层驱动程序。例如PDO_PGSQL()要求您为name参数。
应该是这样的:
return $connect->lastInsertId('yourIdColumn');
使用lastInsertId
$conn->lastInsertId();
(我的)解决方案:
lastInsertId()的参数必须是表名,而不是行名。除此之外,表中必须有一行已检查参数IDENTITY,这就是返回的行。
由此得出的结论是,不可能返回带有lastInsertId()的uniqueidentifier,因为这不能检查参数IDENTITY。
为什么不先执行select newid()然后在插入中使用该id