У меня есть объект с двумя полями, которые используют одну и ту же последовательность, но при отладке я вижу, что генерируется только значение поля id:
@Table(name = "MY_TABLE")
public class MyEntity {
@Id
@Column(name = "ID")
@GenericGenerator(name="my_seq" , type = StringIdGenerator.class)
@GeneratedValue(generator = "my_seq")
private String id;
// Some field
@Column(name = "SOME_OTHER_ID")
@GenericGenerator(name="my_seq" , type = StringIdGenerator.class)
@GeneratedValue(generator = "my_seq")
private String someOtherId;
}
Есть ли способ генерировать значения для столбцов без идентификаторов? Я попробовал использовать BeforeExecutionGenerator, но результат тот же. Я использую Hibernate 6.4.1.
Мой генератор:
public class StringIdGenerator implements IdentifierGenerator {
@Override
public Object generate(SharedSessionContractImplementor session, Object object) {
try (PreparedStatement preparedStatement = session.getJdbcConnectionAccess()
.obtainConnection()
.prepareStatement("SELECT " + sequenceName + ".NEXTVAL as next_val FROM dual")) {
try (ResultSet resultSet = preparedStatement.executeQuery()) {
if (resultSet.next()) {
return String.valueOf(resultSet.getLong("next_val"));
}
}
} catch (SQLException e) {
throw new IdGenerateException("Failed to generate custom ID using sequence", e);
}
}
}
Подробнее здесь: https://stackoverflow.com/questions/788 ... m-sequence
Создать значение, отличное от идентификатора, из последовательности ⇐ JAVA
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Что заставляет strcmp возвращать значение, отличное от 0, 1 или -1? [дубликат]
Anonymous » » в форуме C++ - 0 Ответы
- 25 Просмотры
-
Последнее сообщение Anonymous
-