gpt4 book ai didi

c# - 使用数据库的 FluentValidation 唯一名称验证

转载 作者:IT王子 更新时间:2023-10-29 04:27:26 25 4
gpt4 key购买 nike

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

模型

[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;
}
}

如您所见,我有 UniqueName(string name) 函数,但我如何在其中传递 ID 或整个模型,以便检查它是否与我尝试传递的模型相同编辑然后它通过。我如何传递类似 UniqueName(string name, int?id) 的内容?我今天才发现 FluentValidation,但我想不通。

最佳答案

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;
}

关于c# - 使用数据库的 FluentValidation 唯一名称验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13406270/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com