MyBatis获取上次插入ID

时间:2012-10-31 18:27:33

标签: java sql postgresql insert mybatis

我有一个Java POJO:

public class Widget {
    private int id;
    private String name;
    // ...
}

我正在尝试使用MyBatis将新的Widget插入到Postgres数据库的widget表中,并为此插入方法注入传入的POJO,其中包含自动生成的id新插入的widget表记录:

// Notice the widget's id is left null.
Widget w = new Widget("name-of-widget");

WidgetMapperImpl widgetMapper = new WidgetMapperImpl();
widgetMapper.insertWidget(w);

// At runtime this prints null (the id is not being set).
System.out.println(w.getId());

WidgetMapper.java

public interface WidgetMapper {
    public void insertWidget(@Param("widget") Widget widget);
}

以下是WidgetMapper.xml

<mapper namespace="com.myapp.WidgetMapper">
    <cache flushInterval="360000" />

    <resultMap id="WidgetMapperResult" type="com.myapp.Widget">
        <result property="id" column="widget_id"/>
        <result property="name" column="widget_name" />
    </resultMap>

    <insert id="insertWidget" parameterType="com.myapp.Widget" useGeneratedKeys="true" keyProperty="id">
        INSERT INTO
            myapp.widgets
            (
                widget_name
            )
            VALUES
            (
                #{widget.name}
            );

            <selectKey keyProperty="id" resultType="int" order="AFTER">
                SELECT CURRVAL('widget_id_seq') AS widget_id
            </selectKey>
    </insert>
</mapper>

同样,这段代码编译和构建正常。在运行时,在我调用widgetMapper.insertWidget(Widget)之后,然后尝试访问该Widget的id,它为null,因此ID注入无效。谁能发现原因?提前谢谢!

1 个答案:

答案 0 :(得分:0)

据我记忆,您无法同时使用useGeneratedKeys="true"selectKey

所以解决方案可以是:Postgres的JDBC驱动程序的getGeneratedKeys方法的实现可以处理你需要的东西(我不知道JDBC和postgres序列如何一起工作),所以你使用只有1个}}。或者您必须使用useGeneratedKeys="true",然后您必须转换selectKey属性。