Bài 4 : Cập nhật cơ sở dữ liệu
3. Cập nhật thông qua các quan hệ
Điều làm cho các trình ORM như LINQ to SQL cực kỳ mềm dẻ là nó cho phép chúng ta dễ dàng mơ hình hóa mối quan hệ giữa các bảng trong mơ hình dữ liệu. Ví dụ, tơi có thể mơ hình hóa
39
mỗi Product trong một Category, mỗi Order để chứa các OrderDetails cho từng mục, kết hợp các OrderDetail với một Product, và làm cho mỗi Customer kết hợp với một tập các Order. Tôi đã biểu diễn cách xây dựng và mơ hình hóa các mối quan hệ trong phần 2 của loạt bài này.
LINQ to SQL cho phép tôi tận dụng được ưu điểm của các mối quan hệ trong việc truy vấn và cập nhật dữ liệu. Ví dụ, tơi có thể viết đoạn lệnh dưới đây để tạo một Product mới và kết hợp nó với một category “Beverages” trong CSDL như dưới đây:
(Add đã được thay đổi bằng InsertOnSubmit trong phiên bản hiện tại)
Hãy chú ý cách tôi thêm một đối tượng Product vào tập hợp Products của một Category. Nó sẽ chỉ ra rằng có một mối quan hệ giữa hai đối tượng, và làm cho LINQ to SQL tự động duy trì mối quan hệ foreign-key/primary key giữa cả hai khi tơi gọi SubmitChanges.
Một ví dụ khác cho thấy LINQ to SQL có thể giúp quản lý quan hệ giữa các bảng như thế nào và giúp cho việc lập trình sáng sủa hơn, hãy xem một ví dụ dưới đây khi tôi tạo một Order mới cho một khách hàng đã có. Sau khi đặt giá trị cho ngày chuyển hàng và chi phí cho việc đặt hàng, tơi sẽ tạo tiếp 2 mục chi tiết trong đơn đặt hàng để chỉ đến các sản phẩm mà khách hàng đang muốn mua. Sau đó, tơi sẽ kết hợp đơn đặt hàng với khách hàng, và cập nhật các thay đổi vào CSDL.
LINQ to SQL Tutorial
40
(Add đã được thay đổi bằng InsertOnSubmit trong phiên bản hiện tại)
Như bạn thấy, mơ hình lập trình trên cho phép thực hiện tất cả các công việc này một cách cực kỳ sáng sủa theo phong cách hướng đối tượng.