[英]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.