doulei8861 2013-06-19 11:56
浏览 293

如何在MySQL程序中返回最后插入的id

I use the procedure for user registering

DELIMITER //
CREATE PROCEDURE `regist`(IN login VARCHAR(20), IN password VARCHAR(32), IN ip VARCHAR(15))
BEGIN
INSERT INTO `users` (`login`, `password`, `ip`) VALUES (login, password, ip);
END
//
DELIMITER ;

but how to make the procedure return last inserted id?

  • 写回答

2条回答 默认 最新

  • dongyuan7110 2013-06-19 11:59
    关注

    I've added a OUT parameter in your procedure.

    DELIMITER //
    CREATE PROCEDURE `regist`(IN login VARCHAR(20), IN password VARCHAR(32), IN ip VARCHAR(15), OUT lastId INT)
    BEGIN
    INSERT INTO `users` (`login`, `password`, `ip`) VALUES (login, password, ip);
    SET @last_id = LAST_INSERT_ID();
    END
    //
    DELIMITER ;
    
    评论

报告相同问题?

悬赏问题

  • ¥15 蓝桥oj3931,请问我错在哪里
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染