加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

相当于SQLServer函数SCOPE_IDENTITY()在mySQL中?

发布时间:2020-12-12 07:06:27 所属栏目:MsSql教程 来源:网络整理
导读:什么是相当于SQLServer的功能 SCOPE_IDENTITY()在mySQL? 解决方法 This是你正在寻找: LAST_INSERT_ID() 为了回应OP的评论,我创建了以下测试: CREATE TABLE Foo( FooId INT AUTO_INCREMENT PRIMARY KEY);CREATE TABLE Bar( BarId INT AUTO_INCREMENT PRIMA
什么是相当于SQLServer的功能 SCOPE_IDENTITY()在mySQL?

解决方法

This是你正在寻找:
LAST_INSERT_ID()

为了回应OP的评论,我创建了以下测试:

CREATE TABLE Foo
(
    FooId INT AUTO_INCREMENT PRIMARY KEY
);

CREATE TABLE Bar
(
    BarId INT AUTO_INCREMENT PRIMARY KEY
);

INSERT INTO Bar () VALUES ();
INSERT INTO Bar () VALUES ();
INSERT INTO Bar () VALUES ();
INSERT INTO Bar () VALUES ();
INSERT INTO Bar () VALUES ();

CREATE TRIGGER FooTrigger AFTER INSERT ON Foo
    FOR EACH ROW BEGIN
        INSERT INTO Bar () VALUES ();
    END;

INSERT INTO Foo () VALUES (); SELECT LAST_INSERT_ID();

这返回:

+------------------+
| LAST_INSERT_ID() |
+------------------+
|                1 |
+------------------+

所以它使用原始表的LAST_INSERT_ID(),而不是INSERTed表内的触发器。

编辑:我意识到这一次,我的答案中显示的SELECT LAST_INSERT_ID()的结果是错误的,尽管最后的结论是正确的。我已将结果更新为正确的值。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读