8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

PDO 获取最后插入的 ID

Project.Legion 2月前

33 0

我有一个查询,我想获取插入的最后一个 ID。字段 ID 是主键并且自动递增。我知道我必须使用此语句:LAST_INSERT_ID() 该语句与...

我有一个查询,我想获取插入的最后一个 ID。字段 ID 是主键且自动递增。

我知道我必须使用这个语句:

LAST_INSERT_ID()

该语句适用于如下查询:

$query = "INSERT INTO `cell-place` (ID) VALUES (LAST_INSERT_ID())";

但是如果我想使用这个语句获取 ID:

$ID = LAST_INSERT_ID();

我收到此错误:

Fatal error: Call to undefined function LAST_INSERT_ID()

我做错什么了?

帖子版权声明 1、本帖标题:PDO 获取最后插入的 ID
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由Project.Legion在本站《mysql》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 这是因为这是一个 SQL 函数,而不是 PHP。您可以使用 PDO::lastInsertId() .

    喜欢:

    $stmt = $db->prepare("...");
    $stmt->execute();
    $id = $db->lastInsertId();
    

    如果您想使用 SQL 而不是 PDO API 来执行此操作,您可以像普通选择查询一样执行此操作:

    $stmt = $db->query("SELECT LAST_INSERT_ID()");
    $lastId = $stmt->fetchColumn();
    
  • @rybo111,首先,它是 Screaming 蛇形命名法。其次,它是 MySQL 命名约定,而不是 PHP

  • @rybo111,嗯 SELECT LAST_INSERT_ID() 是一个 MySQL 函数

  • 所以也许这是一个愚蠢的后续问题,但我只是想确定一下。当我依赖 lastInsertId() 时,它是否会返回我当前正在执行的代码中发生的最后一个插入的 ID?还是它会从我的数据库中返回最后一个插入的 ID?例如,如果我有一个流量很大的网站,我在登录脚本中插入了一些内容,并使用 lastInsertId() 来获取插入的 ID,但很多人同时登录,我是否可以安全地依赖 lastInsertId() 从该特定代码执行实例中获取最后一个插入的 ID?或者我是否冒着风险

  • @ArtGeigel 它将是 PDO 实例底层连接的最后插入 ID。换句话说,在您描述的场景中它是安全的,因为并发查询将在单独的连接中进行。

  • lastInsertId() 仅在 INSERT 查询之后起作用。

    正确的:

    $stmt = $this->conn->prepare("INSERT INTO users(userName,userEmail,userPass) 
                                  VALUES(?,?,?);");
    $sonuc = $stmt->execute([$username,$email,$pass]);
    $LAST_ID = $this->conn->lastInsertId();
    

    错误:

    $stmt = $this->conn->prepare("SELECT * FROM users");
    $sonuc = $stmt->execute();
    $LAST_ID = $this->conn->lastInsertId(); //always return string(1)=0
    
返回
作者最近主题: