Việc kiểm tra dữ liệu dựa trên cấu trúc định nghĩa trong CSDL rất hữu ích, nhưng chỉ được coi như ở mức cơ bản, trong thực tế có thể bạn sẽ gặp phải những yêu cầu kiểm tra phức tạp hơn nhiều.
Hãy xem một ví dụ trong CSDL Northwind, khi tôi định nghĩa thuộc tính Phone thuộc lớp Customer có kiểu dữ liệu là nvarchar. Các nhà phát triển dùng LINQ to SQL có thể viết code giống như dưới đây để cập nhật nó với một số phone hợp lệ:
Vấn đề là đoạn code trên được coi là hợp lệ đứng từ góc độ kiểu dữ liệu SQL, vì chuỗi trên vẫn là một chuỗi nvarchar mặc dù có thể nó không phải là một số phone hợp lệ:
LINQ to SQL Tutorial
42
Để tránh việc thêm các số phone kiểu như trên vào CSDL, chúng ta có thể thêm một quy tắc kiểm tra tính hợp lệ vào lớp Customer. Thêm một quy tắc để kiểm tra thực sự đơn giản. Tất cả những gì chúng ta cần làm là thêm một partial class vào và định nghĩa phương thức như dưới đây:
Đoạn code trên tận dụng ưu điểm của 2 đặc tính trong LINQ to SQL:
1) Tất cả các lớp được tạo ra đều là partial – có nghĩa là nhà phát triển có thể dễ dàng thêm vào các phương thức, thuộc tính và thậm chí cả các sự kiện (và đặt chúng trong một file riêng biệt). Điều này làm cho việc thêm các quy tắc xác thực và các hàm phụ trợ vào mô hình dữ liệu và lớp DataContext rất dễ dàng. Bạn không cần cấu hình hay viết thêm các code nào khác để làm được điều này.
2) LINQ to SQL đã tạo sẵn một loạt các điểm mở rộng trong mô hình dữ liệu và lớp DataContext mà bạn có thể dùng để thêm vào các phép kiểm tra dữ liệu trước và sau khi thực hiện các công việc. Nhiều trong số đó ứng dụng một đặc tính ngôn ngữ mới được gọi là “partial method” có trong VB và C# có trong VS 2008 beta 2. Wes Dyer trong nhóm C# có một bài nói về cách các partial method làm việc tại đây.
Trong ví dụ về việc kiểm tra tính hợp lệ dữ liệu ở trên, tôi dùng phương thức OnPhoneChanging, đây là một phương thức sẽ được thực thi bất kỳ lúc nào người dùng gán lại giá trị cho thuộc tính Phone trên một đối tượng Customer. Tôi có thể dùng phương thức này để xác thực giá trị đầu vào theo bất kỳ cách gì tôi muốn (trong ví dụ này, tôi dùng một biểu thức chính quy). Nếu giá trị đã hợp lệ, tôi chỉ đơn giản return và không làm gì cả, khi đó LINQ to SQL sẽ cho là các giá trị này là giá trị hợp lệ, ngược lại tôi có thể phát ra một Exception bên trong phương thức kiểm tra, và phép gán khi đó sẽ không được thực hiện.