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;