使用数据库验证FluentValidation唯一名称

Sta*_*tan 25 c# asp.net asp.net-mvc fluentvalidation asp.net-mvc-4

我有具有名称字段的类别模型,并且每个类别名称必须是唯一的.我已经进行了验证,当我尝试创建新的类别时,它可以正常工作,但在尝试编辑时遇到问题.现在只是检查名称是否存在,当然我在尝试编辑同一类别时也是如此.

模型

[Validator(typeof(CategoryValidator))]
public class Category
{
    public int ID { get; set; }
    public string Name { get; set; }
    virtual public ICollection<Image> Images { get; set; }
}

public class CategoryValidator : AbstractValidator<Category>
{
    public CategoryValidator()
    {
        RuleFor(x => x.Name).NotEmpty().WithMessage("Category name is required.").Must(UniqueName).WithMessage("This category name already exists.");
    }

    private bool UniqueName(string name)
    {
        ProjecteDataContext _db = new ProjecteDataContext();
        var category = _db.Categories.Where(x => x.Name.ToLower() == name.ToLower()).SingleOrDefault();

        if (category == null) return true;
        return false;
    }
}
Run Code Online (Sandbox Code Playgroud)

正如你所看到我有UniqueName(string name)功能,但是如何在其中传递ID或整个模型,以便我可以检查它是否与我正在尝试编辑的模型相同,然后通过.我怎么能传递类似的东西UniqueName(string name, int? id)?我今天才发现FluentValidation,我无法弄明白.

Ser*_*kiy 31

Predicate Validator(aka Must)有一个重载,它接受带有两个参数的谓词(经过验证的对象和属性值).在你的情况下,谓词将具有类型 Func<Category, string, bool>.所以只需将Category参数添加到您的唯一名称验证方法:

private bool UniqueName(Category category, string name)
{
        ProjecteDataContext _db = new ProjecteDataContext();
        var dbCategory = _db.Categories
                            .Where(x => x.Name.ToLower() == name.ToLower())
                            .SingleOrDefault();

        if (dbCategory == null) 
            return true;

        return dbCategory.ID == category.ID;
}
Run Code Online (Sandbox Code Playgroud)

  • 注意:你应该在完成后立即处理DbContext,所以"使用(var _db = new ProjecteDataContext())" (4认同)