休眠 session.save() 总是返回 1

Posted

技术标签:

【中文标题】休眠 session.save() 总是返回 1【英文标题】:Hibernate session.save() always returning 1 【发布时间】:2014-12-17 11:19:01 【问题描述】:

我在 session.save() 中得到了一个奇怪的结果。它始终返回 1。但数据库中的值已正确插入。请提出您认为有疑问的任何内容

代码

session = getSessionFactory().openSession();
Transaction transaction = session.beginTransaction();
userId = (Long)session.save(user);
transaction.commit();

用户 - 持久性

@Id
@GeneratedValue(strategy=GenerationType.SEQUENCE)
@GenericGenerator(name = "increment", strategy = "increment")
@Column(name = "ID")
public Long getId() 
    return id;


public void setId(Long id) 
    this.id = id;


@Column(name = "USERNAME", length = 100)
public String getUsername() 
    return username;


public void setUsername(String username) 
    this.username = username;


@Column(name = "PASSWORD", length = 100)
public String getPassword() 
    return password;


public void setPassword(String password) 
    this.password = password;


@OneToOne(fetch = FetchType.EAGER)
@MapsId
@JoinColumn(name = "ROLEID")
public Role getRole() 
    return role;


public void setRole(Role role) 
    this.role = role;


@Column(name = "IMAGEURL", length = 2000)
public String getImageUrl() 
    return imageUrl;


public void setImageUrl(String imageUrl) 
    this.imageUrl = imageUrl;

版本

休眠:4.3.7 最终版

春季:4.1.2

【问题讨论】:

【参考方案1】:

参考这个问题Difference between @GeneratedValue and @GenericGenerator。

问题可能出在您的@GeneratedValue

所以你可以改变

@GeneratedValue(strategy=GenerationType.SEQUENCE)

@GeneratedValue(generator="increment")

注意:您可以参考 this 将您的数据库序列分配给@GeneratedValue

【讨论】:

您好,感谢您的回复。最初是一样的。我改成这个进行试验和错误。我现在又按照你的建议尝试了,不幸的是它不起作用。 所以 ID 值已正确插入到您的表中? 是的,它已正确插入我的表中。但是返回错误的值 当你说它正确插入时,数据库中的 ID 列值正在递增。该列是表中的主键吗? 是的,是的。你可以在那里看到@Id。它是自动递增的【参考方案2】:

从代码中我看到你的生成策略是序列。但是您错过了将序列映射到注释。

https://docs.oracle.com/javaee/5/api/javax/persistence/GeneratedValue.html

@Id
@GeneratedValue(strategy=GenerationType.SEQUENCE, generator="YOUR_SEQ")
@Column(name = "ID")
public Long getId() 
    return id;

否则,如果您使用的是自定义生成器,那么您应该映射如下:

@Id
@GeneratedValue(generator= "increment")
@GenericGenerator(name = "increment", strategy = "increment")
@Column(name = "ID")
public Long getId() 
    return id;

【讨论】:

您好,再次感谢您的回复。但它不起作用。 您能否提供更多详细信息,例如:您使用的是什么数据库?您是否使用序列来填充主键。你的交易成功了吗? 是的,我得到了它的工作,问题是 onetoOne 映射。实际上是多对多。这限制了结果。

以上是关于休眠 session.save() 总是返回 1的主要内容,如果未能解决你的问题,请参考以下文章

是否使用休眠?

休眠非唯一对象异常

流畅的休眠映射,可双向保存

session.save()返回值问题

休眠:object.org.hibernate.MappingException

多个数据库的休眠自动增量字段