Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
06.06.2018, 15:23
|
|||
---|---|---|---|
|
|||
python и sqlite |
|||
#18+
Здравствуйте. Если в запросе на изменение данных (вставка, обновление записей) в базе использовать конструкцию Код: python 1. 2. 3. 4. 5. 6. 7. 8.
то нужно ли в самих командах вставки и обновления использовать алгоритм “OR ROLLBACK”. То есть так Код: python 1. 2.
При возникновении ошибки изменение не сохранится? Помогите пожалуйста. Спасибо. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
07.06.2018, 20:21
|
|||
---|---|---|---|
python и sqlite |
|||
#18+
MaratD, думаю не нужно (транзакция должна быть атомарной) также можно сократить команды ROLLBACK и COMMIT до одного слова. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
07.06.2018, 21:27
|
|||
---|---|---|---|
python и sqlite |
|||
#18+
MaratD, Зависит от того что тебе нужно. В первом примере (с ловлей исключения), у тебя может произойти исключение в любом месте, не обязательно внутри execute(), но и в любой питоньей команде между обращениями к базе. А в во втором примере откат будет происходить только при ошибке вставки/обновления. Но ошибки питоньего скрипта на базе не отразятся. Оба подхода вполне нормальны, но у них разные области. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
|
start [/forum/topic.php?fid=54&tablet=1&tid=2008450]: |
0ms |
get settings: |
10ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
41ms |
get topic data: |
13ms |
get forum data: |
3ms |
get page messages: |
45ms |
get tp. blocked users: |
2ms |
others: | 251ms |
total: | 387ms |
0 / 0 |