当我插入一行时,我的表的'id'字段自动增加。我想插入一行,然后获取ID。

我会像我说的那样做,但是有没有一种方法可以让我不用担心插入行和获取id之间的时间?

我知道我可以在数据库中查询与输入的信息相匹配的行,但是有很大的变化,会有重复,唯一的区别是id。


当前回答

$link = mysqli_connect('127.0.0.1', 'my_user', 'my_pass', 'my_db');
mysqli_query($link, "INSERT INTO mytable (1, 2, 3, 'blah')");
$id = mysqli_insert_id($link);

看到mysqli_insert_id()。

无论你做什么,不要插入,然后做一个“SELECT MAX(id) FROM mytable”。就像你说的,这是一个竞争条件,没有必要。Mysqli_insert_id()已经有了这个功能。


另一种方法是一次运行两个查询,并使用MySQL的LAST_INSERT_ID()方法,其中两个表被一次修改(PHP不需要任何ID),如:

mysqli_query($link, "INSERT INTO my_user_table ...;
  INSERT INTO my_other_table (`user_id`) VALUES (LAST_INSERT_ID())");

注意,每个连接都单独跟踪ID(因此,已经防止了冲突)。

其他回答

我在上面的链接http://php.net/manual/en/function.mysql-insert-id.php中找到了答案

答案是:

mysql_query("INSERT INTO tablename (columnname) values ('$value')");        
echo $Id=mysql_insert_id();
$link = mysqli_connect('127.0.0.1', 'my_user', 'my_pass', 'my_db');
mysqli_query($link, "INSERT INTO mytable (1, 2, 3, 'blah')");
$id = mysqli_insert_id($link);

看到mysqli_insert_id()。

无论你做什么,不要插入,然后做一个“SELECT MAX(id) FROM mytable”。就像你说的,这是一个竞争条件,没有必要。Mysqli_insert_id()已经有了这个功能。


另一种方法是一次运行两个查询,并使用MySQL的LAST_INSERT_ID()方法,其中两个表被一次修改(PHP不需要任何ID),如:

mysqli_query($link, "INSERT INTO my_user_table ...;
  INSERT INTO my_other_table (`user_id`) VALUES (LAST_INSERT_ID())");

注意,每个连接都单独跟踪ID(因此,已经防止了冲突)。

一个例子。

    $query_new = "INSERT INTO students(courseid, coursename) VALUES ('', ?)";
    $query_new = $databaseConnection->prepare($query_new);
    $query_new->bind_param('s', $_POST['coursename']);
    $query_new->execute();
    $course_id = $query_new->insert_id;
    $query_new->close();

代码行$course_id = $query_new->insert_id;将显示最后插入行的ID。 希望这能有所帮助。

MySQL函数LAST_INSERT_ID()所做的正是您所需要的:它检索在会话期间插入的id。因此,使用它是安全的,即使有其他进程(例如,其他人调用完全相同的脚本)将值插入到同一个表中。

PHP函数mysql_insert_id()的作用与使用mysql_query()调用SELECT LAST_INSERT_ID()相同。

我只想添加一个关于lastInsertId()的小细节;

当一次输入多个行时,它不会返回最后一个Id,而是返回最后一个插入集合的第一个Id。

考虑下面的例子

$sql = 'INSERT INTO my_table (varNumb,userid) VALUES
     (1, :userid),
     (2, :userid)';
$sql->addNewNames = $db->prepare($sql);
addNewNames->execute(array(':userid' => $userid));

echo $db->lastInsertId();

这里发生的事情是,我在my_table中插入两行新行。该表的id是自动递增的。这里,对于同一个用户,我用不同的varNumb添加了两行。

最后的回显值将等于varNumb=1的行id,这意味着不是最后一行的id,而是在最后一个请求中添加的第一行的id。