2

私はJavaPOJOを持っています:

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

WidgetMyBatisを使用してPostgresデータベースのテーブルに新しいものを挿入しようとしていwidgetます。この挿入メソッドでは、渡された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)てからそのIDにアクセスしようとすると、Widgetnullであるため、IDインジェクションが機能しません。誰かが理由を見つけることができますか?前もって感謝します!

4

1 に答える 1

0

私が覚えている限り、あなたは同時に使うことはできませuseGeneratedKeys="true"selectKey

したがって、解決策は次のようgetGeneratedKeysになります。Postgres用のJDBCドライバーのメソッドの実装は、必要なものを処理できるため(JDBCとpostgresシーケンスがどのように連携するかはわかりません)、を使用するだけuseGeneratedKeys="true"です。または、を使用する必要selectKeyがあります。次に、useGeneratedKeys属性をオフにする必要があります。

于 2012-10-31T18:51:32.523 に答える