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 ответов

10 просмотров

На самом деле, на уровне сетевого протокола есть 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 (не знаю кто это), бывает.

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

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

Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Коллеги, добрый вечер. Создаю коллекцию от TFPGMap, ключ - перечисление, значение - целое. Нужно отсортировать коллекцию по значению. Как это можно сделать?
Kirill Filippenok
11
Скажи а ты когда этот канал создавал ты уже дельфи не любил, или это со временем пришло?
Роман Лях (rgreat)
18
Привет, такой вопросик появился кажется ли вам что Rust слишком сложный/строгий для высокоуровневого программирования и слишком "безопасный"/строгий для низкоуровневого?
Крокант
10
Всем привет! Использую кастомное модальное диалоговое окошко, все по классике - mrOK, mrCancel как ModalResult. Однако есть нюанс - в главной форме есть универсальный обработч...
Олег Гранишевский
20
Карта сайта