Создать значение, отличное от идентификатора, из последовательностиJAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Создать значение, отличное от идентификатора, из последовательности

Сообщение Anonymous »

У меня есть объект с двумя полями, которые используют одну и ту же последовательность, но при отладке я вижу, что генерируется только значение поля 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
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «JAVA»