Разница между FOR UPDATE и FOR SHARE при блокировке строк в PostgreSQL заключается в следующем:
- FOR UPDATE. postgrespro.ru dev.to В этом режиме строки, выданные оператором SELECT, блокируются как для изменения. postgrespro.ru Они защищаются от блокировки, изменения и удаления другими транзакциями до завершения текущей. postgrespro.ru
- FOR SHARE. postgrespro.ru habr.com Для каждой из полученных строк запрашивается разделяемая, а не исключительная блокировка. postgrespro.ru Разделяемая блокировка не позволяет другим транзакциям выполнять с этими строками UPDATE, DELETE, SELECT FOR UPDATE или SELECT FOR NO KEY UPDATE, но допускает SELECT FOR SHARE и SELECT FOR KEY SHARE. postgrespro.ru
Таким образом, FOR UPDATE используется, когда нужно, чтобы выбранные строки оставались неизменными до завершения транзакции, а другие транзакции не могли изменить или заблокировать эти строки конфликтующим образом. dev.to FOR SHARE применяется, когда нужно прочитать строку, но при этом нельзя допустить, чтобы она как-либо изменилась другой транзакцией. habr.com