В Oracle читатели не блокируют писателей. Таким образом, один сеанс может читать строку одновременно с тем, что другой сеанс обновляет или удаляет эту строку. Читатель увидит строку в том виде, в каком она существовала, по номеру системного изменения (SCN), с которого начался запрос.
Единственное время, когда возможна блокировка, - это если два сеанса одновременно пытаются обновить или удалить одну и ту же строку. Это, как правило, не создает каких-либо исключений. Вместо этого, какой бы сеанс не ожидал блокировки, он просто блокировался до тех пор, пока удерживающий сеанс не снял блокировку, завершив транзакцию. Вы можете получить исключение, если вы укажете время ожидания для блокировки или если Oracle обнаружит, что ваш код заблокирован и должен завершить один из сеансов взаимоблокировки для решения проблемы.