170 похожих чатов

@Vladimirsitnikv у меня вот всё равно не очень стыкуются два

утверждения:
1. Твое - "База создаёт транзакцию только тогда, когда речь доходит до модификации данных (ну или хотя бы блокировки через select for update). Поэтому, после select'а, который как бы readonly, никакой транзакции остаться не может"
2. Из документации - "PostgreSQL actually treats every SQL statement as being executed within a transaction. If you do not issue a BEGIN command, then each individual statement has an implicit BEGIN and (if successful) COMMIT wrapped around it". Плюс, есть вот такое https://www.postgresql.org/message-id/4071D840.3040205@opencloud.com, где говорят `With autocommit off, a SELECT (or in fact *any* query) will start a new
transaction. It's your responsibility to eventually close that
transaction (via commit() or rollback()) at an apropriate point`
Что же на самом деле происходит?

2 ответов

13 просмотров

На самом деле, на уровне сетевого протокола есть 2 разные возможности выполнить select запрос. Если драйвер знает, что «autocommit==false», то драйвер уверен в том, что он может использовать более сложный механизм, и «порталы» (==курсоры) не закроются сами собой. Если же драйвер видит, что autocommit==true, то он не может использовать хитроумный механизм с порталами (и соответственно, fetch N запросами).

>With autocommit off, a SELECT (or in fact *any* query) will start a new >transaction. It's your responsibility to eventually close that >transaction (via commit() or rollback()) at an apropriate point. Некоторые ошибаются. Это пример ошибочного утверждения. Ну, ошибся Oliver Jowett (не знаю кто это), бывает.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта