powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / нежданчик
5 сообщений из 5, страница 1 из 1
нежданчик
    #38867870
этта
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
прослал батч вида

Код: sql
1.
2.
3.
4.
5.
BEGIN ; {DO something}; END;
BEGIN ; {DO something}; END;
BEGIN ; {DO something}; END;
........
BEGIN ; {DO something}; END;



-- слежу снаружи -- всё путём -- результаты очередного {DO something}; в табличке всё время появляются.

надумал последить через pg_stat_activity -- а там... -- строка стоит как вкопанная. Все ее xact_start, и прочие state_change -- намертво залипли.

-- т.е. чего-то я в этом деле неверно понимаю.

кто в курсе, что происходит ? и почему ? (не меняется xact_start)
...
Рейтинг: 0 / 0
нежданчик
    #38867910
Alexius
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
этта,

у меня в таком тесте все меняется как надо:

Код: sql
1.
2.
3.
4.
5.
6.
7.
begin; select pg_sleep(1); end;
begin; select pg_sleep(1); end;
begin; select pg_sleep(1); end;
begin; select pg_sleep(1); end;
begin; select pg_sleep(1); end;
begin; select pg_sleep(1); end;
begin; select pg_sleep(1); end;



может не тот процесс в pg_stat_activity?
...
Рейтинг: 0 / 0
нежданчик
    #38867938
этта
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Alexius,

А вы этот скрипт куда кормите ?

я -- в соединение [окно] пжодмина (читай-- любого клиента, кроме разборчивого по-командам psql [, если того не просить об обратном]), одним сплошным батчем (т.е. он целиком в pg_staе_activity.query и лежит). (т.е. это как-то там называется. multicomand или т.п. mode). Всегда было недосуг последить в пг-стат-активити за такими батчами.


вот думаю теперь -- если пжодмин батч оборачиваетсам,ля в общий BEGIN; END; -- то все равно непонятки выходят -- на первом "моЁм" begin-е notice дожен придти-- его там обычно нет. Да и первый попавшийся END; должен слистнуть транзакцию.

ваш запустил так же -- то же самое (но что оно делает -- я наружу не вижу. у себя то я вижу, что коммиты проходят -- по данным)
...
Рейтинг: 0 / 0
нежданчик
    #38868081
Alexius
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
этта,

в psql. в pgadmin повторяется, да.

это видимо недостаток pg_stat_activity, он похоже считает весь запрос одной транзакцией/частью транзакции, хотя на самом деле это не так.

гугление по multi-statement query и pg_stat_activity/statistics collector ничего не дало, мало кто на это натыкается наверное.
...
Рейтинг: 0 / 0
нежданчик
    #38868100
этта
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Alexius,

я слегка погуглил, ничего не нашел. Интересно, что отдельные части этого мултистейтмента в логи не попадают. (а могли бы -- по duration).

последний раз тут maxim Bogyk заикался, про эту крайне удобную фичу ( 13437301 ).



но забавная ситуация -- "мультистейтмент" один, транзацкий в нем много.
и самое забавное: -- данные-то потихоньку комитятся. а время старта "транзакции" -- ни с места.
...
Рейтинг: 0 / 0
5 сообщений из 5, страница 1 из 1
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / нежданчик
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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