Отключение пакетной обработки Hibernate - PullRequest
1 голос
/ 07 февраля 2012

Чтобы отладить проблему с использованием Hibernate, я бы хотел отключить механизм пакетной вставки / обновления Hibernate, чтобы вместо этого использовать не пакетные операторы.

Я знаю, что могу установить hibernate.jdbc.batch_size=1, но это все равно проходит через обычный код пакета с размером пакета 1.

Есть ли способ полностью отключить пакетную обработку?

Ответы [ 2 ]

2 голосов
/ 07 февраля 2012

Прямо из документации :

hibernate.jdbc.batch_size: ненулевое значение позволяет использовать пакетные обновления JDBC2 в Hibernate.например, рекомендуемые значения от 5 до 30

1 голос
/ 07 февраля 2012

Насколько я понимаю, вы хотите избежать вызова метода PreparedStatement # addBatch (sql) из Hibernate (и вместо этого использовать выделенный экземпляр оператора для каждой операции). К сожалению, нет простого способа сделать это. Но ... Я проверил исходный код Hibernate, и кажется, что Hibernate проверяет несколько условий перед запуском операции обновления / вставки. Это решает, использовать ли партию или нет. Взгляните на метод AbstractEntityPersister # update. Должна быть строка вроде этой:

final boolean useBatch = j == 0 && expectation.canBeBatched() && isBatchable(); //note: updates to joined tables can't be batched...

Одна вещь, которую вы можете сделать, это заменить метод isBatchable () вашей собственной реализацией, которая всегда будет возвращать false. По умолчанию это выглядит так:

public boolean isBatchable() {
        return optimisticLockMode()==Versioning.OPTIMISTIC_LOCK_NONE ||
            ( !isVersioned() && optimisticLockMode()==Versioning.OPTIMISTIC_LOCK_VERSION ) ||
            getFactory().getSettings().isJdbcBatchVersionedData();
    } 

Поэтому вы можете выбрать один из следующих подходов:

  • создайте свою собственную реализацию EntityPersister
  • заменить исходный код Hibernate
  • настроить конфигурацию, установив свойство hibernate.jdbc.batch_versioned_data = false и установив режим блокировки для каждой сущности, для которой требуется OPTIMISTIC_LOCK_ALL.

Как я уже говорил, не просто, но возможно.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...