sql INSERT之后的PHP返回ID[uniqueidentifier]


PHP Return ID[uniqueidentifier] after sql INSERT

正如标题所说,我希望在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