powered by simpleCommunicator - 2.0.53     © 2025 Programmizd 02
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Продолжить транзакцию после ошибки INSERT
4 сообщений из 4, страница 1 из 1
Продолжить транзакцию после ошибки INSERT
    #39795121
prustr
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Делаю импорт большого файла, иногда в столбце с integer присутствует текст непотребный, что приводит к ошибке вставки данных.
Раньше делал так (через php - pgPDO) обрабатываю построчно, вставляю, ловлю в try catch ошибку, пишу ее в лог, продолжаю обработку дальше.
Но на очень больших файлах это к очень долгому импорту. Отсюда решение - вставку делаю в тарнзакции:
Код: php
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
$this->db->beginTransaction();
$stmt = $this->db->prepare($sql);

while ($row = fgetcsv($handle, 4096, $eparator, $delimiter)) {
// ....
try {
$stmt->execute($params);
} catch (Exeption $e){
    ile_put_contents($log, $e->getMessage());
    continue;
}

}

$this->db->commit();



Применение транзакции ускорило ипорт примерно в 100 раз, так что отказываться от транзакции уже не хочу, но вот беда catch сбрасывает транзакцию и на следующем шаге после ошибки я получаю исключение:
"ОШИБКА: текущая транзакция прервана, команды до конца блока транзакции игнорируются"

Вопрос: есть ли флаги какие у PDO или способ организации запроса какой хитрый, чтобы пропустить плохую строку, транзакцию не прерывать и работать дальше.
Почему не пишу свой валидатор? Полей много, времени мало, все файлы разные, пользователь сам мапирует столбцы - а валидатор сервера - он же вполне себе хорош, и сообщения на двух языках, и коды, все уже при нем... только вот транзакция рвется.
...
Рейтинг: 0 / 0
Продолжить транзакцию после ошибки INSERT
    #39795261
prustr
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
deadline
буду писать валидотор :)

PS погуглил - в MSSQL есть что то типа save-точек. Транзакцию можно откатить не к началу, а к этой точке... но это другая БД
...
Рейтинг: 0 / 0
Продолжить транзакцию после ошибки INSERT
    #39795282
ОКТОГЕН
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
prustrdeadline
буду писать валидотор :)

PS погуглил - в MSSQL есть что то типа save-точек. Транзакцию можно откатить не к началу, а к этой точке... но это другая БД
https://postgrespro.ru/docs/postgresql/11/sql-savepoint
...
Рейтинг: 0 / 0
Продолжить транзакцию после ошибки INSERT
    #39795828
lr2
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
lr2
Гость
try = exception
...
Рейтинг: 0 / 0
4 сообщений из 4, страница 1 из 1
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Продолжить транзакцию после ошибки INSERT
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]