微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

MySQL插入后如何返回主键序列号

如何解决MySQL插入后如何返回主键序列号

我正在使用 flex builder 4 编写 actionscript 以在表中插入一行。该表有一个主键,比如带有 AUTO_INCREMENT 的 iddCourse。在FB4中,我曾经有dataservice PHP插入行,它会返回新创建的行的序列号,即存储在iddCourse中的生成编号。例如在插入之前,iddCourse 中记录的最后一个序列号是 179,新创建的行的 iddCourse 将为 180。并且,我可以通过 ResultEvent 获得这个数字 180。实际代码如下:

protected function createCourseHere(event:ResultEvent):void
    {
        rspCreateCourse.token = svcCourse.createCourse(voCourseSaved);
        rspCreateCourse.addEventListener(ResultEvent.RESULT,onRspCreateCourse);
    }
    
    protected function onRspCreateCourse(event:ResultEvent):void
    {   
        rspCreateCourse.removeEventListener(ResultEvent.RESULT,onRspCreateCourse);
        voCourseSaved.iddCourse = event.result as int;
        acCourse.addItem(voCourseSaved);
        acCourse = UtilArray.sortAc1(acCourse,"txtCourseCodeE","S","A");
        UtilMessage.sendMessage("Course created");
    }

你可以看到我使用event.result as int来找出新创建的行的序号。最近,我将数据服务更改为 HTTPService 而不是 PHP(使用 ZendamF)。现在, event.result 结果为空,因此我无法找出创建的最新序列号。当然,我可以再次访问服务器以通过其他键获取新创建的行并找出序列号,但我不这样做。有没有办法从ResultEvent中的actionscript中找出HTTPService数据服务新创建的主键序列号?

解决方法

我曾经用这些代码解决了同样的问题,也许对你有帮助

var result:SQLResult = new SQLResult();
stat.clearParameters();
stat.text = "select len from property_unit_designer_temp where id=?"
stat.parameters[0] = id;
stat.execute();
result = stat.getResult();
return result.lastInsertRowID;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。