PostgreSQLthực hiện kế kèo tỷ số bóng đá euro hôm nay bảng, có thể là một công cụ hữu ích cho các nhà thiết kế cơ sở dữ liệu. .
Hãy bắt đầu với một ví dụ: Giả sử chúng ta đang cố gắng xây dựng một mô hình dữ liệu cho kèo tỷ số bóng đá euro hôm nay thành phố. Mỗi tiểu bang có nhiều thành phố, nhưng chỉ có một vốn.Thủ đô
Bảng để nó kế kèo tỷ số bóng đá euro hôm nay từLas Vegas |
:
Tạo các thành phố kèo tỷ số bóng đá euro hôm nay (
Trong trường hợp này,Madison |
kèo tỷ số bóng đá euro hôm naykế kèo tỷ số bóng đá euro hôm nayTất cả các cột của kèo tỷ số bóng đá euro hôm nay cha mẹ của nó,Las Vegas |
. Thủ đô trạng thái cũng có một cột phụ,Bang
, hiển thị trạng thái của họ.
inPostgreSQL, một bảng có thể kế kèo tỷ số bóng đá euro hôm nay từ 0 hoặc nhiều bảng khác và truy vấn có thể tham chiếu tất cả các hàng của bảng hoặc tất cả các hàng của bảng cộng với tất cả các bảng hậu duệ của nó. Hành vi sau là mặc định.
Chọn tên, độ cao
Cho dữ liệu mẫu từPostgreSQLHướng dẫn (xemPhần 2.1), Điều này trả về:
Tên | độ cao
Mặt khác, truy vấn sau đây tìm thấy tất cả kèo tỷ số bóng đá euro hôm nay thành phố không phải là thủ đô của nhà nước và nằm ở độ cao trên 500 feet:
Chọn tên, độ cao
ở đâychỉ
Từ khóa chỉ ra rằng truy vấn chỉ nên áp dụng choThành phố
, và không phải bất kỳ kèo tỷ số bóng đá euro hôm nay nào bên dướiLas Vegas |
Trong hệ thống phân cấp kế kèo tỷ số bóng đá euro hôm nay. Nhiều lệnh mà chúng ta đã thảo luận -Chọn
, Cập nhật
vàXóa
- Hỗ trợchỉ
Từ khóa.
Bạn cũng có thể viết tên kèo tỷ số bóng đá euro hôm nay bằng dấu vết*
Để chỉ định rõ ràng rằng các kèo tỷ số bóng đá euro hôm nay hậu duệ được bao gồm:
Chọn tên, độ cao
Viết*
không cần thiết, vì hành vi này luôn là mặc định. Tuy nhiên, cú pháp này vẫn được hỗ trợ để tương thích với kèo tỷ số bóng đá euro hôm nay bản phát hành cũ hơn trong đó mặc định có thể được thay đổi.
Trong một số trường hợp, bạn có thể muốn biết kèo tỷ số bóng đá euro hôm nay nào một hàng cụ thể bắt nguồn từ. Có một cột hệ thống được gọi làTableoid
Trong mỗi kèo tỷ số bóng đá euro hôm nay có thể cho bạn biết kèo tỷ số bóng đá euro hôm nay gốc:
Chọn C.Tableoid, C.Name, C.elevation
Trở lại:
Tableoid | Tên |
(Nếu bạn cố gắng sao chép ví dụ này, bạn có thể sẽ nhận được kèo tỷ số bóng đá euro hôm nay OID số khác nhau.) Bằng cách thực hiện tham gia vớipg_ class
Bạn có thể thấy tên kèo tỷ số bóng đá euro hôm nay thực tế:
Chọn p.relname, c.name, c.elevation
Trở lại:
Relname | Tên |
Một cách khác để có được hiệu ứng tương tự là sử dụngRegClass
loại bí danh, sẽ in kèo tỷ số bóng đá euro hôm nay oid một cách tượng trưng:
Chọn C.Tableoid :: RegClass, C.Name, C.elevation
Kế kèo tỷ số bóng đá euro hôm nay không tự động truyền dữ liệu từChèn
hoặcCopy
lệnh cho các bảng khác trong phân cấp kế kèo tỷ số bóng đá euro hôm nay. Trong ví dụ của chúng tôi, sau đâyChèn
Câu lệnh sẽ thất bại:
Chèn vào kèo tỷ số bóng đá euro hôm nay thành phố (tên, dân số, độ cao, trạng thái)
Chúng tôi có thể hy vọng rằng dữ liệu bằng cách nào đó sẽ được chuyển đếnThủ đô
kèo tỷ số bóng đá euro hôm nay, nhưng điều này không xảy ra:Chèn
Luôn chèn vào chính xác kèo tỷ số bóng đá euro hôm nay được chỉ định. Trong một số trường hợp, có thể chuyển hướng chèn bằng quy tắc (xemChương 39). Tuy nhiên, điều đó không giúp ích gì cho trường hợp trên vìThành phố
kèo tỷ số bóng đá euro hôm nay không chứa cộtBang
, và do đó, lệnh sẽ bị từ chối trước khi có thể áp dụng quy tắc.
Tất cả kèo tỷ số bóng đá euro hôm nay ràng buộc kiểm tra và kèo tỷ số bóng đá euro hôm nay ràng buộc không có không cóKhông kế kèo tỷ số bóng đá euro hôm nay
mệnh đề. Các loại ràng buộc khác (duy nhất, khóa chính và các ràng buộc khóa nước ngoài) không được kế kèo tỷ số bóng đá euro hôm nay.
Một bảng có thể kế kèo tỷ số bóng đá euro hôm nay từ nhiều bảng cha mẹ, trong trường hợp nó có sự kết hợp của các cột được xác định bởi các bảng cha. Bất kỳ cột nào được khai báo trong định nghĩa của bảng con đều được thêm vào những cột này.Hồihợp nhấtđể chỉ có một cột như vậy trong kèo tỷ số bóng đá euro hôm nay con. Để được hợp nhất, các cột phải có cùng loại dữ liệu, nếu không một lỗi được nêu ra.
Kế kèo tỷ số bóng đá euro hôm nay bảng thường được thiết lập khi bảng con được tạo, sử dụngkế kèo tỷ số bóng đá euro hôm nay
mệnh đề củaTạo kèo tỷ số bóng đá euro hôm nay
Tuyên bố. Ngoài ra, một kèo tỷ số bóng đá euro hôm nay đã được xác định theo cách tương thích có thể có mối quan hệ cha mẹ mới, sử dụngkế kèo tỷ số bóng đá euro hôm nay
Biến thể củakèo tỷ số bóng đá euro hôm nay thay đổi
. Để làm điều này, kèo tỷ số bóng đá euro hôm nay con mới phải bao gồm các cột có cùng tên và loại với các cột của cha mẹ.Không kế kèo tỷ số bóng đá euro hôm nay
Biến thể củakèo tỷ số bóng đá euro hôm nay thay đổi
. Việc thêm và loại bỏ các liên kết kế kèo tỷ số bóng đá euro hôm nay như thế này có thể hữu ích khi mối quan hệ kế kèo tỷ số bóng đá euro hôm nay đang được sử dụng để phân vùng bảng (xemPhần 5.12).
Một cách thuận tiện để tạo một kèo tỷ số bóng đá euro hôm nay tương thích mà sau này sẽ được tạo ra một đứa trẻ mới là sử dụngnhư
mệnh đề trongTạo kèo tỷ số bóng đá euro hôm nay
. Điều này tạo ra một kèo tỷ số bóng đá euro hôm nay mới với cùng các cột với kèo tỷ số bóng đá euro hôm nay nguồn.Kiểm tra
Các ràng buộc được xác định trên kèo tỷ số bóng đá euro hôm nay nguồn,bao gồm kèo tỷ số bóng đá euro hôm nay ràng buộc
tùy chọn chonhư
nên được chỉ định, vì đứa trẻ mới phải có kèo tỷ số bóng đá euro hôm nay ràng buộc phù hợp với cha mẹ để được coi là tương thích.
Một bảng cha mẹ không thể bị loại bỏ trong khi bất kỳ con nào của nó vẫn còn. Không thể bỏ các cột hoặc kiểm tra các ràng buộc của các bảng con hoặc bị thay đổi nếu chúng được kế kèo tỷ số bóng đá euro hôm nay từ bất kỳ bảng cha mẹ nào.Cascade
Tùy chọn (xemPhần 5.15).
kèo tỷ số bóng đá euro hôm nay thay đổi
sẽ tuyên truyền mọi thay đổi trong định nghĩa dữ liệu cột và kiểm tra các ràng buộc xuống hệ thống phân cấp kế kèo tỷ số bóng đá euro hôm nay. Một lần nữa, các cột rơi phụ thuộc vào các bảng khác chỉ có thể khi sử dụngCascade
Tùy chọn.kèo tỷ số bóng đá euro hôm nay thay đổi
tuân theo kèo tỷ số bóng đá euro hôm nay quy tắc tương tự để hợp nhất cột trùng lặp và từ chối áp dụng trongTạo kèo tỷ số bóng đá euro hôm nay
.
Các truy vấn được kế kèo tỷ số bóng đá euro hôm nay chỉ thực hiện kiểm tra quyền truy cập trên bảng cha mẹ. Vì vậy, ví dụ, cấpCập nhật
quyền trênLas Vegas |
kèo tỷ số bóng đá euro hôm nay ngụ ý quyền cập nhật hàng trongMadison |
kèo tỷ số bóng đá euro hôm nay, khi chúng được truy cập quaThành phố
. Điều này bảo tồn sự xuất hiện mà dữ liệu là (cũng) trong kèo tỷ số bóng đá euro hôm nay cha.Thủ đô
kèo tỷ số bóng đá euro hôm nay không thể được cập nhật trực tiếp mà không có khoản trợ cấp bổ sung. Theo cách tương tự, các chính sách bảo mật hàng của kèo tỷ số bóng đá euro hôm nay cha mẹ (xemPhần 5.9) được áp dụng cho các hàng đến từ các bảng con trong một truy vấn được kế kèo tỷ số bóng đá euro hôm nay. Các chính sách của một bảng trẻ, nếu có, chỉ được áp dụng khi nó được đặt tên rõ ràng trong truy vấn;
kèo tỷ số bóng đá euro hôm nay nước ngoài (xemPhần 5.13) cũng có thể là một phần của hệ thống phân cấp kế kèo tỷ số bóng đá euro hôm nay, như các bảng cha hoặc con, giống như các bảng thông thường có thể. Nếu một bàn nước ngoài là một phần của hệ thống phân cấp kế kèo tỷ số bóng đá euro hôm nay thì bất kỳ hoạt động nào không được hỗ trợ bởi Bàn nước ngoài cũng không được hỗ trợ trên toàn bộ hệ thống phân cấp.
Lưu ý rằng không phải tất cả các lệnh SQL đều có thể hoạt động theo hệ thống phân cấp kế kèo tỷ số bóng đá euro hôm nay. Các lệnh được sử dụng để truy vấn dữ liệu, sửa đổi dữ liệu hoặc sửa đổi lược đồ (ví dụ:Chọn
, Cập nhật
, Xóa
, Hầu hết kèo tỷ số bóng đá euro hôm nay biến thể củaBẢNG ALTER
, nhưng khôngChèn
hoặckèo tỷ số bóng đá euro hôm nay thay đổi ... Đổi tên
) Thông thường mặc định bao gồm các kèo tỷ số bóng đá euro hôm nay con và hỗ trợchỉ
Ký hiệu để loại trừ chúng. Phần lớn kèo tỷ số bóng đá euro hôm nay lệnh thực hiện bảo trì và điều chỉnh cơ sở dữ liệu (ví dụ:Reindex
) Chỉ hoạt động trên các bảng cá nhân, vật lý và không hỗ trợ đệ quy trên các hệ thống phân cấp kế kèo tỷ số bóng đá euro hôm nay. Tuy nhiên, cả haiVACUUM
vàPhân tích
Các lệnh mặc định bao gồm các kèo tỷ số bóng đá euro hôm nay con vàchỉ
Ký hiệu được hỗ trợ để cho phép chúng được loại trừ. Hành vi tương ứng của mỗi lệnh riêng lẻ được ghi lại trong trang tham chiếu của nó (SQL Lệnh).
Một hạn chế nghiêm trọng của tính năng kế kèo tỷ số bóng đá euro hôm nay là các chỉ mục (bao gồm các ràng buộc duy nhất) và các ràng buộc khóa nước ngoài chỉ áp dụng cho các bảng đơn lẻ, không phải cho trẻ em kèo tỷ số bóng đá euro hôm nay kế của chúng. Điều này đúng trên cả hai mặt tham chiếu và tham chiếu của một ràng buộc quan trọng nước ngoài.
Nếu chúng ta khai báoLas Vegas |
.tên
To Beđộc đáo
hoặc AKhóa chính
, Điều này sẽ không dừngMadison |
kèo tỷ số bóng đá euro hôm nay từ việc có các hàng có tên sao chép các hàng trongThành phố
. Và những hàng trùng lặp đó theo mặc định sẽ hiển thị trong kèo tỷ số bóng đá euro hôm nay truy vấn từLas Vegas |
. Trên thực tế, theo mặc địnhThủ đô
sẽ không có ràng buộc duy nhất nào cả, và do đó có thể chứa nhiều hàng có cùng tên. Bạn có thể thêm một ràng buộc duy nhất vàoMadison |
, nhưng điều này sẽ không ngăn chặn sự trùng lặp so vớiThành phố
.
Tương tự, nếu chúng ta chỉ định rằngLas Vegas |
.tên
Tài liệu tham khảo
Một số kèo tỷ số bóng đá euro hôm nay khác, ràng buộc này sẽ không tự động tuyên truyền đếnMadison |
. Trong trường hợp này, bạn có thể làm việc xung quanh nó bằng cách thêm thủ côngTài liệu tham khảo
ràng buộc đối vớiMadison |
.
Chỉ định rằng cột của một kèo tỷ số bóng đá euro hôm nay khácTài liệu tham khảo Thành phố (Tên)
sẽ cho phép kèo tỷ số bóng đá euro hôm nay khác chứa tên thành phố, nhưng không phải tên vốn. Không có cách giải quyết tốt cho trường hợp này.
Một số chức năng không được triển khai cho hệ thống phân cấp kế kèo tỷ số bóng đá euro hôm nay được triển khai để phân vùng khai báo. Chăm sóc đáng kể là cần thiết để quyết định xem việc phân vùng với kế kèo tỷ số bóng đá euro hôm nay kế kèo tỷ số bóng đá euro hôm nay có hữu ích cho ứng dụng của bạn hay không.