2

我有一个 Java POJO:

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

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

// 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),然后尝试访问它的Widgetid,它是 null,所以 ID 注入不起作用。谁能发现为什么?提前致谢!

4

1 回答 1

0

据我记得,你不能同时使用useGeneratedKeys="true"selectKey

所以一个解决方案可以是:要么实现getGeneratedKeysJDBC driver for Postgres 的方法就可以处理你所需要的(我不知道 JDBC 和 postgres 序列是如何协同工作的),所以你只使用useGeneratedKeys="true". 或者你必须使用selectKey,然后你必须打开useGeneratedKeys属性。

于 2012-10-31T18:51:32.523 回答