Tìm hiểu View trong MySql là gì?

MySQL là hệ quản trị cơ sở dữ liệu quan hệ sử dụng ngôn ngữ truy vấn có cấu trúc (SQL)

MySQL là có tốc độ cao, ổn định và dễ sử dụng, có tính khả chuyển, hoạt động trên nhiều hệ điều hành cung cấp một hệ thống lớn các hàm tiện ích rất mạnh.

MySQL có nhiều phiên bản cho các hệ điều hành khác nhau: Windows, Linux, Mac OS X, Unix, FreeBSD, NetBSD, Novell NetWare, SGI Irix, Solaris, SunOS,…

MySQL được sử dụng cho việc bổ trợ PHPPerl, và nhiều ngôn ngữ khác, nó làm nơi lưu trữ những thông tin trên các trang web viết bằng PHP hay Perl,…MySQL Workbench là trình trực quan để giao tiếp với MySQL, nó thực hiện hiển thị đồ họa cho người dùng như các bảng, các database, mô hình… Nếu không có nó thì ta sẽ phải giao tiếp với MySQL bằng giao diện dòng lệnh khá phức tạp và mất thời gian.(Một số phần mềm giống như MySQL Workbench như SQLoy, SQLWorkbench J…)

1. View trong MySQL là gì?

Về mặt ngữ nghĩa thì View giống như là xem hoặc nhìn, nhưng ở khía cạnh hệ quản trị cơ sở dữ liệu thì View có tác dụng giống như tạo một Table ảo với các Fields và Records mà ta có thể tự định nghĩa và khác hoàn tòa với Table gốc.

View có đầy đủ các tính chất của một Table nên ta có thể truy vấn bằng cách sửu dụng các lệnh T-SQL trên nó, không những thế bạn có thể delete và tạo mới View thông qua một câu lệnh đơn giản.

Khi ta tạo một View từ một table thì nếu table đó đổi dữ liệu thì mặc nhiên View cũng sẽ thay đổi theo. Điều này thật tuyệt vời vì ta không mất nhiều công sức để cập nhật lại dữ liệu.

Để rõ hơn thì mình lấy một ví dụ thế này: Giả sử trang Frontend có một Block gọi là hiển thị 10 tin mới nhất, như vậy ta sẽ truy vấn lấy 10 tin và sắp xếp giảm dần theo ID. Nhưng bạn biết trong SQL nó sẽ duyệt toàn bộ bảng rồi mới trả về kết quả và điều này làm cho truy vấn trở nên chậm chạm.

Để giải quyết nó thì ta sẽ tạo một View gồm 10 tin mới nhất và lúc hiển thị ra chỉ cần lấy trong View nên tốc độ sẽ nhanh hơn rất nhiều lần.

2. Ưu điểm khi sử dụng View trong MySQL

Sau đây chúng ta sẽ thảo luận về những lợi ích khi sử dụng View nhé.

Khi sử dụng Database View sẽ giúp bạn đơn giản hóa các câu truy vấn phức tạp bởi vì một View được tạo ra bởi một câu truy vấn SQL, nên dữ liệu mà nó lưu trữ ta có thể gọi là thành phẩm của một công đoạn truy vấn nên giải quyết được nhiều vấn đề về tốc độ, đặc biệt là những câu truy vấn JOIN. Bạn có thể sử dụng View để che giấu đi sự phức tạp của mô hình dữ liệu trong hệ thống bởi những gì mà họ thấy chỉ là môt View rất đơn giản.

  • Database View giúp giới hạn dữ liệu cho người sử dụng, nghĩa là một View sẽ có bấy nhiêu dữ liệu thôi và người dùng chỉ được thấy con số bấy nhiêu đó. Ngoài ra khi tạo View bạn có thể gán quyền truy cập sử dụng cho một nhóm nào đó. Tôi lấy một ví dụ thực tế như sau, giả sử hệ thống của bạn có phần danh sách hóa đơn và bạn muốn những nhân viên trong bộ phận Kế Toán được phép xem các hóa đơn trong tháng này thôi. Như vậy bạn sẽ tạo một View và dữ liệu của nó là danh sách hóa đơn của tháng hiện tại, sau đó gán quyền vào nhóm Kế Toán này.
  • Database View giúp tăng tính bảo mật hơn bởi vì View chi đọc mà không ghi được (Read Only) nên việc hacker tấn công cập nhật dữ liệu là điều không thể.
  • Database View cho phép tăng hoặc giảm các Fields tùy theo yêu cầu sử dụng bởi vì nó được tạo từ một câu truy vấn SELECT nên bạn có thể JOIN nhiều Table lại với nhau và lưu vào View.
  • Database View tăng khả năng phát triển lại ứng dụng hoặc tương thích với nhiều ứng dụng chạy chung một CSDL. Ví dụ như bạn có một hệ thống dữ liệu khách hàng và một này nào đó bạn cần đổi cấu trúc thì lúc này trong Source của bạn phải đổi theo. Nhưng nếu sử dụng View thì ta có thể hạn chế được việc này.

3. Nhược điểm khi sử dụng View trong MYSQL

Ưu điểm có thì đương nhiên nhược điểm cũng phải có. Và sau đây là những nhược điểm của Database View.

  • Khi truy vấn trong View có thể sẽ chậm hơn trong table
  • Bị phụ thuộc vào Table gốc, nếu Table gốc thay đổi cấu trúc thì đòi hỏi View cũng phải thiết kế lại cho phù hợp

4. Database View trong MySql

MYSQL có hỗ trợ View nhưng từ phiên bản 5.X mới có và hầu hết những đặc tính của nó theo chuẩn View của năm năm 2003.

MYSQL sẽ lưu file lưu trữ View với tên là view_name.frm-00001, sau này bạn cập nhật lại bố cục của nó thì nó sẽ lưu lại là view_name.frm-00002 và cứ tăng dần như thế.

Để hiểu rõ hơn thì có lẽ bạn phải chờ xem bài sau nhé, ở bài sau ta sẽ học cách tạo View trong MYSQL.

Leave a reply:

Your email address will not be published.

Site Footer

Sliding Sidebar

Facebook