我有一个场景,我不想允许重复的数据库条目,为此我使用Remote Validation属性。 内部模型
[Remote("DepartmentNameExists", "Department", "Department Name is already taken.")]
public string Name { get; set; }
内部控制器
public JsonResult DepartmentNameExists(string name)
{
var user = db.Departments.Where(x => x.Name == name.Trim());
return !user.Any() ?
Json(true, JsonRequestBehavior.AllowGet) :
Json(string.Format("{0} is allready exists.", name),
JsonRequestBehavior.AllowGet);
}
它适用于创建视图,但是当转到编辑时出现一些问题,例如在编辑页面上提交单击它将再次验证名称并阻止页面提交,因为数据库中已有相同的条目(这是我目前的活跃项目本身)。我怎么解决这个问题? 注意:我无法从编辑页面中删除验证,因为用户可能会输入任何其他现有名称而不是当前名称。
答案 0 :(得分:2)
您需要使用AdditionalFields
RemoteAttribute
并使用该表的Id
(主键)。
[Remote("DepartmentNameExists", "Department", "Department Name is already taken.", AdditionalFields = "Id")]
public string Name { get; set; }
在控制器中,检查名称是否存在,但您当前正在编辑的名称除外。
public JsonResult DepartmentNameExists(string name, int id = 0)
{
return db.Departments.Any(x => x.Name == name.Trim() && x.Id != id)
? Json(string.Format("{0} already exists.", name),
JsonRequestBehavior.AllowGet)
: Json(true, JsonRequestBehavior.AllowGet);
}