RuleUniqueValueAttribute Class
Defines a validation rule that demands the target property’s value be unique.
Namespace: DevExpress.Persistent.Validation
Assembly: DevExpress.Persistent.Base.v24.1.dll
NuGet Package: DevExpress.Persistent.Base
Declaration
Remarks
Apply this attribute to a business class property to define a validation rule that will check whether this property’s value is unique. Use the CriteriaEvaluationBehavior parameter, to specify whether to look for objects that are currently retrieved from the database, in addition to objects in the database itself. In addition, use the common parameters that are inherited from the RuleBaseAttribute class.
[RuleUniqueValue("",DefaultContexts.Save,
CriteriaEvaluationBehavior=CriteriaEvaluationBehavior.BeforeTransaction)]
public virtual Priority Priority { get; set; }
// Make sure that you use options.UseChangeTrackingProxies() in your DbContext settings.
The rule generated by the RuleUniqueValueAttribute will be loaded to the Application Model‘s IModelValidationRules node. So, you can customize this rule via the Model Editor. In addition, you can create new rules in the Model Editor as well. This is helpful when you need to add a rule to a property which is implemented in a base class provided by a third party library. For details, refer to the Implement Property Value Validation topic.
You can see examples of using the RuleUniqueValue and other validation attributes in the Validation section of the FeatureCenter demo. This demo is located in the %PUBLIC%\Documents\DevExpress Demos 24.1\Components\XAF\FeatureCenter.NETFramework.XPO folder, by default.
Note
You can apply RuleUniqueValue
, RuleObjectExists, RuleIsReferenced, and RuleCombinationOfPropertiesIsUnique rules to persistent business objects only because they search for objects within the application database. If the rule is applied to a base class that has descendants, the condition is tested against objects of all derived types.