Table inheritance là một tính năng mạnh mẽ trong PostgreSQL cho phép bạn tạo ra các bảng con (child tables) dựa trên các bảng cha (parent tables). Điều này giúp tổ chức dữ liệu theo cách phân cấp, cho phép các bảng con kế thừa cấu trúc và dữ liệu từ bảng cha, đồng thời cũng có thể có thêm các cột và đặc tính riêng.

Dưới đây là giải thích chi tiết về table inheritance trong PostgreSQL, bao gồm các khái niệm cơ bản, cách sử dụng, lợi ích và nhược điểm.

1. Khái Niệm Cơ Bản

1.1. Bảng Cha và Bảng Con

  • Bảng Cha (Parent Table): Là bảng chính, chứa các cột chung cho tất cả các bảng con.
  • Bảng Con (Child Table): Là bảng được tạo ra từ bảng cha, có thể kế thừa tất cả các cột và dữ liệu từ bảng cha và có thể thêm các cột riêng.

1.2. Kế Thừa Dữ Liệu

Khi một bảng con kế thừa từ bảng cha, nó tự động nhận tất cả các cột của bảng cha. Dữ liệu có thể được chèn vào bảng cha hoặc bảng con, và cả hai sẽ có thể truy cập dữ liệu từ bảng cha.

2. Cách Tạo Bảng Inheritance

2.1. Tạo Bảng Cha

Đầu tiên, bạn cần tạo một bảng cha. Ví dụ:

CREATE TABLE vehicles (
    id SERIAL PRIMARY KEY,
    name VARCHAR(100),
    type VARCHAR(50)
);

2.2. Tạo Bảng Con

Tiếp theo, bạn có thể tạo một bảng con kế thừa từ bảng cha:

CREATE TABLE cars (
    doors INT
) INHERITS (vehicles);

Ở đây, bảng cars kế thừa từ bảng vehicles và thêm cột doors.

3. Truy Vấn Dữ Liệu

Khi truy vấn dữ liệu từ bảng cha, PostgreSQL sẽ tự động bao gồm dữ liệu từ các bảng con. Ví dụ:

SELECT * FROM vehicles;

Câu lệnh trên sẽ trả về tất cả các bản ghi từ bảng vehicles cũng như từ bảng cars.

4. Quản Lý Dữ Liệu

4.1. Chèn Dữ Liệu

Bạn có thể chèn dữ liệu vào cả bảng cha và bảng con. Ví dụ:

INSERT INTO vehicles (name, type) VALUES ('Toyota', 'Car');
INSERT INTO cars (name, type, doors) VALUES ('Honda', 'Car', 4);

4.2. Xóa Dữ Liệu

Khi xóa dữ liệu từ bảng cha, dữ liệu trong các bảng con không bị xóa trừ khi bạn chỉ định:

DELETE FROM vehicles WHERE id = 1; -- Xóa từ bảng cha

5. Lợi Ích và Nhược Điểm

5.1. Lợi Ích

  • Tổ Chức Dữ Liệu: Giúp tổ chức dữ liệu theo cấu trúc phân cấp, dễ quản lý hơn.
  • Tái Sử Dụng Cột: Giúp tái sử dụng các cột chung cho nhiều bảng mà không cần phải lặp lại mã.

5.2. Nhược Điểm

  • Khó Khăn Trong Việc Quản Lý: Khi có nhiều bảng con, việc quản lý có thể trở nên phức tạp.
  • Hiệu Suất: Truy vấn có thể chậm hơn nếu bảng cha chứa nhiều dữ liệu, do việc quét dữ liệu từ nhiều bảng.

6. Kết Luận

Table inheritance trong PostgreSQL là một tính năng hữu ích cho phép bạn tổ chức dữ liệu theo cách phân cấp, giảm thiểu sự lặp lại và cho phép quản lý dữ liệu hiệu quả hơn. Tuy nhiên, cần cân nhắc kỹ lưỡng về cách sử dụng để tránh những phức tạp không cần thiết trong việc quản lý và truy vấn dữ liệu.