PostgreSQL
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> PostgreSQL

Chế độ khóa PostgreSQL

Đúng là INSERT , UPDATE hoặc DELETE phải có được ROW EXCLUSIVE khóa trên bàn để được cập nhật.

Tuy nhiên, khóa này không ngăn SELECT từ hoạt động bình thường. SELECT chỉ yêu cầu ACCESS SHARE Khóa. Khóa này tương thích với ROW EXCLUSIVE - nói cách khác, bạn có thể thực thi SELECT một cách hoàn hảo trong khi dữ liệu khác được cập nhật bởi INSERT , UPDATE hoặc DELETE , miễn là bạn không có được bất kỳ khóa rõ ràng nào.

Nói cách khác, bạn sẽ không bao giờ thấy bất kỳ bế tắc nào khi sử dụng cách tiếp cận thứ hai (chỉ cần không sử dụng SELECT FOR UPDATE và bạn sẽ ổn).

Đọc thêm trong tài liệu PostgreSQL .




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Tại sao Postgres không sử dụng chỉ mục?

  2. Cách giải quyết Phương pháp org.postgresql.jdbc.PgConnection.createBlob () chưa được triển khai

  3. Đặt application_name trên Postgres / SQLAlchemy

  4. Đổi tên một giá trị enum dẫn đến Không tìm thấy mối quan hệ kiểu

  5. Kiểm tra xem một hàng có tồn tại hay không trong postgresql