私はJavaPOJOを持っています:
public class Widget {
private int id;
private String name;
// ...
}
Widget
MyBatisを使用して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にアクセスしようとすると、Widget
nullであるため、IDインジェクションが機能しません。誰かが理由を見つけることができますか?前もって感謝します!