gpt4 book ai didi

java - MyBatis 获取最后插入的 Id

转载 作者:行者123 更新时间:2023-11-29 12:27:46 25 4
gpt4 key购买 nike

我有一个 Java POJO:

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

我正在尝试使用 MyBatis 将一个新的 Widget 插入到我的 Postgres 数据库的 widget 表中,并为此插入方法注入(inject)传入的 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) 之后,然后尝试访问那个 Widget 的 id,它是 null,所以 ID 注入(inject)不起作用.谁能看出为什么?提前致谢!

最佳答案

据我所知,您不能同时使用 useGeneratedKeys="true"selectKey

所以一个解决方案可以是:要么实现 Postgres 的 JDBC 驱动的 getGeneratedKeys 方法就可以处理你需要的东西(我不知道 JDBC 和 postgres sequences 是如何协同工作的),所以你只使用 useGeneratedKeys="true"。或者您必须使用 selectKey,然后您必须关闭 useGeneratedKeys 属性。

关于java - MyBatis 获取最后插入的 Id,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13165349/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com