Cập nhật thông qua các quan hệ

Một phần của tài liệu LinQ To Sql (Trang 38 - 40)

Đ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.

Một phần của tài liệu LinQ To Sql (Trang 38 - 40)