Назад к вопросам
IT One
Senior
8
Задача #2 Какой результат будет в сессии Session #2? Подключение к БД с пустой таблицей t Session #1 --------------------------- psql> BEGIN; -- T1 psql(T1)> INSERT INTO t(id,val) VALUES (1,'a'); -- no COMMIT psql(T1)> COMMIT; --------------------------- Session #2 --------------------------- psql(T2)> SELECT * FROM t; ---------------------------
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
В Session #2 результатом будет пустой набор строк.
Объяснение:
- В Session #1 выполняется BEGIN, затем INSERT, но COMMIT вызывается после INSERT.
- Однако в условии указано "no COMMIT" после INSERT, а потом COMMIT, что противоречиво. Если предположить, что COMMIT не был вызван, то транзакция не зафиксирована.
- Если транзакция в Session #1 не была зафиксирована (COMMIT не выполнен), то изменения не видны другим сессиям.
Таким образом, при выполнении SELECT * FROM t; в Session #2, таблица t останется пустой, так как вставка не была зафиксирована и не видна другим сессиям.