Cách tạo view và những lợi ích khi sử dụng

Phụ lục
cach-tao-view-va-nhung-loi-ich-khi-su-dung

Ở phần kiến thức hôm nay mình tiếp tục chia sẻ về VIEW, là một khái niệm nâng cao hơn so với các bài trước đây. Và kiến thức này cũng hay được sử dụng trong khi làm dự án.

View trong SQL là gì?

Là table ảo (virtual) dựa trên kết quả từ câu lệnh SQL SELECT. Và nó cũng có các dòng và cột nhưng là table thật. Vậy hãy cùng theo dõi tiếp bên dưới nó có gì khác với table thật hay không.

Mục đích sử dụng VIEW

Giúp thao tác nhanh với dữ liệu mà không cần viết lại câu lệnh SQL SELECT từ đầu. Vì nó cũng chứa các dòng và cột như table thật, nên chúng ta có thể thao tác như một table thông thường.

3. Hướng dẫn thao tác với VIEW trong SQL

3.1. Tạo VIEW

Cú pháp


CREATE VIEW view_name AS
SELECT column1, column2, ...
FROM table_name
WHERE condition;

Lưu ý: Dữ liệu ở VIEW luôn được cập nhật theo dữ liệu mới nhất ở table chính.

Ví dụ

Tạo ra VIEW để liệt kê ra toàn bộ thông tin các bác sĩ và thông tin tài khoản. Với các bác sĩ chưa có tài khoản, hay tài khoản chưa có ai sở hữu thì cũng phải liệt kê ra.


CREATE VIEW view_full_join AS
SELECT d.doctor_id, d.last_name, a.account
FROM doctor d
LEFT JOIN account_system a ON d.doctor_id = a.doctor_id
UNION ALL
SELECT d.doctor_id, d.last_name, a.account
FROM doctor d
RIGHT JOIN account_system a ON d.doctor_id = a.doctor_id;

3.2. Thao tác với VIEW

Tiếp tục ví dụ bên trên, vì VIEW là một table ảo, nên bạn có thể dùng SELECT để truy vấn như một table thật:


SELECT *
FROM view_full_join;

Nhưng bạn hãy nhớ một số lưu ý khi muốn cập nhật dữ liệu (INSERT, UPDATE, DELETE) trên VIEW:

  • VIEW không chứa GROUP BY, ORDER BY.
  • Không chứa DISTINCT.
  • Nên chứa cả các column NOT NULL.
  • Không chứa sub query.
  • VIEW chỉ nên được tạo từ 1 table.

3.3. Để cập nhật cấu trúc VIEW

Khi bạn muốn cập nhật cấu trúc VIEW, hãy sử dụng với cú pháp:


CREATE OR REPLACE VIEW view_name AS
SELECT column1, column2, ...
FROM table_name
WHERE condition;

3.4. Xoá VIEW

Như là các khái niệm được tạo ra bởi CREATE, thì khi xoá chúng ta cũng sẽ sử dụng DROP như bên dưới:


DROP VIEW view_name;

Kết luận

Nếu trong dự án xuất hiện nhiều câu lệnh truy vấn phức tạp, thì hãy sử dụng VIEW để giải quyết vấn đề này. Ngoài ra, VIEW cũng có nhiều loại, các bạn hãy tìm hiểu thêm để linh hoạt trong cách sử dụng nhé.


Devwork

Devwork là Nền tảng TUYỂN DỤNG IT CẤP TỐC với mô hình kết nối Nhà tuyển dụng với mạng lưới hơn 30.000 headhunter tuyển dụng ở khắp mọi nơi.Với hơn 1800 doanh nghiệp IT tin dùng Devwork để :

  • Tối ưu chi phí
  • Tiết kiệm thời gian
  • Tăng tốc tuyển dụng tối đa
  • Đăng ký ngay Devwork trong hôm nay để tuyển dụng những tài năng ưu tú nhất.

    Tag Cloud:

    Tác giả: quyenntt

    Link chia sẻ

    Bình luận

    Việc làm tại Devwork

    khám phá các cơ hội việc làm tốt nhất tại Devwork Xem thêm

    Bài viết liên quan

    Danh sách bài viết liên quan có thể bạn sẽ thích Xem thêm
    database-administrator-la-gi

    Database Administrator là gì? Ai phù hợp với nghề quản trị cơ sở dữ liệu? 

    07:11 26/06/2025

    Database Administrator (DBA) là gì và tại sao vai trò này lại đang trở thành một trong những nghề nghiệp được săn đón nhất trong lĩnh vực công nghệ thông tin? Devwork giới thiệu đến bạn tổng quan về nghề nghiệp đầy tiềm năng này, từ định nghĩa, trách nhiệm, lộ trình phát triển đến cơ hội việc làm và mức lương hấp dẫn của một DBA....

    QC là gì? 5 điều phải biết trước khi theo nghề “kiểm soát chất lượng"

    06:59 26/06/2025

    Bạn đang tìm hiểu về nghề QC? Bạn muốn biết QC là gì, công việc của một nhân viên QC ra sao, và liệu đây có phải là con đường sự nghiệp phù hợp với mình? Bài viết này sẽ cung cấp cho bạn cái nhìn toàn diện về vị trí QC, từ định nghĩa, vai trò, công việc, đến cơ hội phát triển trong ngành.

    bo-phan-qc-la-gi

    Visual Studio Code là gì? Hướng dẫn cài đặt & sử dụng

    06:47 26/06/2025

    Bạn đang bắt đầu học lập trình và nghe nhiều người nhắc đến Visual Studio Code? Đây là một trong những công cụ phổ biến nhất được các lập trình viên trên toàn thế giới tin dùng. Trong bài viết này, hãy cùng tìm hiểu Visual Studio Code là gì, vì sao nó được ưa chuộng, và cách bạn có thể bắt đầu với nó dễ dàng.

    visual-studio-code-la-gi

    IoT là gì? Cấu tạo & Nguyên lý hoạt động của hệ thống Internet vạn vật

    06:39 26/06/2025

    Trong kỷ nguyên số, IoT là gì và tại sao nó đang thay đổi cách chúng ta sống và làm việc? Từ nhà thông minh đến thành phố thông minh, công nghệ IoT đang mở ra vô vàn cơ hội. Cùng Devwork khám phá cách IoT hoạt động, ứng dụng thực tiễn và tiềm năng phát triển trong tương lai!

    lap-trinh-iot-la-gi
    syntax-la-gi

    Tìm hiểu syntax là gì và vai trò của cú pháp trong lập trình

    01:23 26/06/2025

    Syntax là phần không thể thiếu trong bất kỳ ngôn ngữ lập trình nào. Chỉ cần sai một ký tự nhỏ, chương trình có thể ngừng hoạt động. Hãy cùng khám phá syntax là gì và vì sao bạn cần hiểu rõ nó từ sớm.

    tim-hieu-jvm-la-gi

    JVM là gì? Cách hoạt động và vai trò trong lập trình Java

    08:12 25/06/2025

    Bạn đang tìm hiểu về nền tảng Java nhưng còn băn khoăn về khái niệm JVM là gì? Devwork sẽ giải đáp thắc mắc với bài viết toàn diện về Java Virtual Machine - thành phần cốt lõi giúp Java trở thành ngôn ngữ lập trình đa nền tảng phổ biến hàng đầu thế giới.