Khái niệm về quan hệ

Một phần của tài liệu Giáo trình môn họcmô đun lập trình PHP căn bản (ngànhnghề thiết kế trang web) (Trang 142 - 143)

6. PHÁT BIỂU SQLD ẠNG JOIN

6.1. Khái niệm về quan hệ

Để phát triển ứng dụng Web bằng bất kỳ loại cơ sở dữ liệu nào, giai đoạn phân tích thiết kế hệ thống cực kỳ quan trọng. Nếu kết quả phân tích không tối ƣu thì ứng dụng đó không thể đạt đƣợc giá trị kỹ thuật cũng nhƣ giá trị thƣơng mại. Thiết kế cơ sở dữ liệu không tối ƣu,

chúng có thể dẫn đến việc chƣơng trình chạy chậm và không bền vững.

Một khi ứng dụng chạy chậm đi do cơ sở dữ liệu không tối ƣu thì rất có thể bạn phải thiết kế và xây dựng lại từđầu toàn bộ cấu trúc của chƣơng trình và cơ sở dữ liệu.

Xuất phát từ lý do này, khi xây dựng một ứng dụng thông tin quản lý, chúng ta cần phải qua những bƣớc phân tích thiết kế hệ thống kỹlƣỡng để có đƣợc mô hình quan hệ và ERD

trƣớc khi đến các mô hình chức năng chi tiết.

Tuy nhiên, trong lý thuyết một số kiến thức cơ bản bắt buộc bạn phải thực hiện theo mô hình hệ thống ứng với những quan hệ toàn vẹn, nhƣng trong thực tế, do tính đặc thù của ứng dụng, thƣờng bạn phải thiết kế lại mô hình theo nhu cầu cân đối giữa độ phức tạp và tính tối

ƣu.

Trong ứng dụng bán hàng qua mạng Test đã trình bày trong chƣơng 3, khi quan tâm đến một hợp đồng trên mạng, ngoài những thông tin liên lạc về khách hàng, bạn cần phải lƣu trữ

dữ liệu khác nhƣ chiết hàng mua, phƣơng thức trả tiền, phƣơng thức giao hàng,... Vấn đề đƣợc thảo luận ởđây, mỗi hợp đồng có nhì6u mặt hàng chi tiết.

Trong trƣờng hợp này, chúng ta có 6 thực thể liên quan nhƣ sau, thực thể danh mục

Customers (thông tin liên lạc của khách hàng), Orders (hợp đồng mua hàng), OrderDetails

(chi tiết hàng mua), Items (danh mục sản phẩm).

Trang 141

Sơ đồ 8-1: Mô hình quan hệ

Giả sử rằng khi nhập số liệu vào cơ sở dữ liệu, ứng với hợp đồng có mã 101, của khách hàng có tên Nguyễn Văn A, ... có hai sản phẩm chi tiết: 11 (Nƣớc ngọt) và 32 (xà phòng

Lux).

Trong trƣờng hợp này bạn đang có một mẩu tin hợp đồng trong bảng tblCustomers, một mẩu tin hợp đồng trong bảng tblOrders và hai mẩu tin trong bảng tblOrderDetails.

Nếu muốn biết thông tin hợp đồng của khách hàng A, rõ ràng bạn cần dùng phát biểu

SELECT với mệnh đề kết hợp từ 3 bảng trên. Kết quả trả về 2 mẩu tin là sự kết hợp thông tin từ hai bảng tblCustomers, tblOrders và tblOrderDetails.

Khi thực thi phát biểu SQL dạng SELECT ứng với cơ sở dữ liệu nhƣ trên bạn phải duyệt qua hai mẩu tin.

Tất nhiên, khi viết ứng dụng thì điều này chấp nhận đƣợc, và có thể coi là tối ƣu. Giả sử

rằng, ứng dụng này đƣợc phát triển trên WEB cần lƣu tâm đến vấn đề tối ƣu tốc độ truy vấn thì sao?

Ngƣời thiết kếcơ sở dữ liệu trong trƣờng hợp này phải thay đổi lại cấu trúc để tăng tốc

độ truy cập qua mạng khi xửlý trên cơ sở dữ liệu của ngƣời dùng.

Một phần của tài liệu Giáo trình môn họcmô đun lập trình PHP căn bản (ngànhnghề thiết kế trang web) (Trang 142 - 143)

Tải bản đầy đủ (PDF)

(183 trang)