在更新或添加到数据库之前,是否有任何关于如何连接需要与数据库交互的验证的链接或建议?我看到的每个示例都显示了如何验证属性,例“是必需的”,“是电子邮件”,“是数字”等,但是如何连接“无法订购缺货商品”的验证?
This xVal blog post触及它但没有提供一个例子.
我一直在关注使用存储库的NerdDinner教程,但这是我不太明白的…说我们有一个带有Create方法的OrderController,在创建订单之前我们必须首先检查该项目有货在NerdDinner样式中,Controller使用Repository与数据库进行通信,那么我们的Order对象(Model)如何能够与属性验证一起强制执行此验证,因为它无法与数据库通信?
谢谢你的帮助
解决方法
在NerdDinner教程中,您可以签出IsVaild,然后签出GetRuleViolation方法.根据您的业务和数据库规则,您可以使用这些规则检查插入之前的数据.您甚至可以创建一个IsValidForInsert方法来检查您需要强制执行的任何插入特定规则.
在NerdDinner中,GetRuleViolation允许您检索违反的规则,并根据您的选择将它们冒泡到界面.
public bool IsValid { get { return (GetRuleViolations().Count() == 0); } } public IEnumerable<RuleViolation> GetRuleViolations() { if (CheckDbForViolation) yield return new RuleViolation("Database Violation","SomeField"); if (String.IsNullOrEmpty(Title)) yield return new RuleViolation("Title is required","Title"); if (String.IsNullOrEmpty(Description)) yield return new RuleViolation("Description is required","Description"); if (String.IsNullOrEmpty(HostedBy)) yield return new RuleViolation("HostedBy is required","HostedBy"); ... etc ... yield break; } public bool CheckDbForViolation() { /// Do your database work here... }
您可以进一步将数据库代码拆分到存储库中. CheckDbForViolation将调用repo获取信息,然后确定是否存在违规.事实上,如果您使用的是存储库,我认为这是最好的方法.