gpt4 book ai didi

java - 我可以在 Hibernate 中创建自己的序列吗?

转载 作者:搜寻专家 更新时间:2023-11-01 03:14:05 24 4
gpt4 key购买 nike

我可以在 Hibernate 中创建自己的序列吗? ,就像我有一个数据库序列,我必须在序列前添加 2 个字符?

最佳答案

您可以创建自己的标识符生成器。看看这个blog post这基本上展示了如何做类似于你正在寻找的事情(除非我误解了这个问题):

Custom Hibernate Sequence Generator for Id field

I have a table with a primary key in the format M001, M002 etc (lets not think about what happens after M999 for now). I’m using Hibernate Annotations, and I found a great way of generating the Primary Key value for new Records:

First I created a database sequence to use. Then I implemented org.hibernate.id.IdentifierGenerator;

public class StockCodeGenerator implements IdentifierGenerator {

private static Logger log = Logger.getLogger(StockCodeGenerator.class);

public Serializable generate(SessionImplementor session, Object object)
throws HibernateException {

String prefix = "M";
Connection connection = session.connection();
try {

PreparedStatement ps = connection
.prepareStatement("SELECT nextval ('seq_stock_code') as nextval");

ResultSet rs = ps.executeQuery();
if (rs.next()) {
int id = rs.getInt("nextval");
String code = prefix + StringUtils.leftPad("" + id,3, '0');
log.debug("Generated Stock Code: " + code);
return code;
}

} catch (SQLException e) {
log.error(e);
throw new HibernateException(
"Unable to generate Stock Code Sequence");
}
return null;
}
}

Then, in my entity class, I simply annotate the id field like this:

@Id
@GenericGenerator(name="seq_id", strategy="my.package.StockCodeGenerator")
@GeneratedValue(generator="seq_id")
@Column(name = "stock_code", unique = true, nullable = false, length = 20)
public String getStockCode() {
return this.stockCode;
}

关于java - 我可以在 Hibernate 中创建自己的序列吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3649652/

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