Phiên bản được hỗ trợ:hiện tại(17) /16 / 15 / 14 / 13
Phiên bản phát triển:18 / Devel
Phiên bản không được hỗ trợ:12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3 / 7.2
Tài kèo bóng đá c1 này dành cho phiên bản không được hỗ trợ của PostgreSQL.
Bạn có thể muốn xem cùng một trang chohiện tạiPhiên bản hoặc một trong các phiên bản được hỗ trợ khác được liệt kê ở trên thay thế.

3.3. Chìa kèo bóng đá c1

nhớ lạithời tiếtThành phốBảng từChương 2. Xem xét những điều sau đây Vấn đề: Bạn muốn đảm bảo rằng không ai có thể chèn hàng vàothời tiếtbảng không có Kết hợp mục nhập trongThành phốBảng. Cái này được gọi là duy trìTính toàn vẹn tham chiếucủa dữ kèo bóng đá c1 của bạn. Trong đơn giản Các hệ thống cơ sở dữ kèo bóng đá c1 này sẽ được triển khai (nếu có) trước tiên Nhìn vàoThành phốBảng đến kiểm tra xem bản ghi phù hợp có tồn tại không, sau đó chèn hoặc từ chối mớithời tiếtBản ghi. Cách tiếp cận này có một số vấn đề và rất bất tiện, Vì thếPostgreSQLcó thể làm điều này cho Bạn.

Tuyên bố mới kèo bóng đá c1 các bảng sẽ trông như thế này:

Tạo các thành phố bảng (
        kèo bóng đá c1 chính của thành phố (80),
        Điểm vị trí
);

Tạo thời tiết bàn (
        Thành phố Varchar (80) Tài liệu tham khảo Thành phố (Thành phố),
        TEMP_LO INT,
        TEMP_HI INT,
        PRCP thật,
        Ngày ngày
);

Bây giờ hãy thử chèn một bản ghi không hợp lệ:

Chèn vào các giá trị thời tiết ('Berkeley', 45, 53, 0.0, '1994-11-28');
Lỗi: chèn hoặc cập nhật trên bảng "thời tiết" vi phạm ràng buộc kèo bóng đá c1 "Weather_city_fkey"
Chi tiết: Key (Thành phố) = (Berkeley) không có trong bảng "Thành phố".

Hành vi của các kèo bóng đá c1 có thể được điều chỉnh tinh xảo với bạn ứng dụng. Chúng tôi sẽ không vượt ra ngoài ví dụ đơn giản này trong điều này hướng dẫn, nhưng chỉ cần giới thiệu bạn đếnChương 5Để biết thêm thông tin. Sử dụng chính xác các kèo bóng đá c1 sẽ Chắc chắn cải thiện chất lượng của các ứng dụng cơ sở dữ liệu của bạn, vì vậy Bạn được khuyến khích mạnh mẽ để tìm hiểu về họ.