簡體   English   中英

MyBatis獲取最后插入ID

[英]MyBatis Get Last Insert Id

我有一個Java POJO:

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

我正在嘗試使用MyBatis將新的Widget插入我的Postgres數據庫的widget表中,並且對於此insert方法,使用新插入的widget表記錄的自動生成的ID注入傳入的POJO:

// 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注入不起作用。 誰能找到原因? 提前致謝!

據我所知,您不能同時使用useGeneratedKeys="true"selectKey

因此,解決方案可以是:用於Postgres的JDBC驅動程序的getGeneratedKeys方法的實現getGeneratedKeys您的需要(我不知道JDBC和postgres序列如何協同工作),因此僅使用useGeneratedKeys="true" 或者,您必須使用selectKey ,然后必須打開useGeneratedKeys屬性。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM