UniqueEntity

编辑本页

警告:您正在浏览的文档欧宝官网下载appob娱乐下载Symfony 2.8,现已不再维护。

本页的更新版本用于Syob娱乐下载mfony 6.2(当前稳定版本)。

UniqueEntity

验证Doctrine实体中的一个(或多个)特定字段是否惟一。例如,这通常用于防止新用户使用系统中已经存在的电子邮件地址注册。

基本用法

假设你有一个AppBundle包用户具有电子邮件字段。您可以使用UniqueEntity约束来保证电子邮件字段在你的用户表中的所有约束之间保持唯一:

  • 注释
  • YAML
  • XML
  • PHP
12 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
/ / src / AppBundle /实体/ Author.php名称空间AppBundle\实体使用ob娱乐下载\组件\验证器\约束作为断言使用学说\ORM\映射作为ORM//不要忘记这个use语句!!使用ob娱乐下载\\学说\验证器\约束\UniqueEntity/ * * *@ORM* \实体@UniqueEntity(“电子邮件”)* /作者/ * * *@var字符串$email * *@ORM\列(name="email", type="string", length=255, unique=true) *@Assert\电子邮件* /受保护的电子邮件/ /……

谨慎

这个约束没有提供任何保护竞态条件.当外部流程在验证通过后持久化另一个实体,并且在该实体实际持久化到数据库之前持久化该实体时,可能会发生这种情况。

选项

字段

类型数组|字符串默认的选项

这个必需的选项是这个实体应该是唯一的字段(或字段列表)。例如,如果同时指定电子邮件而且的名字场在一个单一UniqueEntity约束,那么它将强制组合值是唯一的(例如,两个用户可以有相同的电子邮件,只要他们也没有相同的名字)。

如果你需要两个字段分别是唯一的(例如,一个唯一的电子邮件而且一个独特的用户名),你用两个UniqueEntity条目,每个条目只有一个字段。

消息

类型字符串默认的此值已被使用。

当此约束失败时显示的消息。

您可以在此消息中使用以下参数:

参数 描述
{{value}} 当前(无效)值

新兴市场

类型字符串

用于进行查询以确定惟一性的实体管理器的名称。如果它为空,将为该类确定正确的实体管理器。因此,可能不需要使用此选项。

repositoryMethod

类型字符串默认的findBy ()

用于进行查询以确定惟一性的存储库方法的名称。如果为空,则findBy ()方法将被使用。这个方法应该返回一个可计数的结果。

errorPath

类型字符串默认的:中第一个字段的名称字段

如果实体违反约束,则错误消息将绑定到中的第一个字段字段.如果有多个字段,您可能希望将错误消息映射到另一个字段。

想想这个例子:

  • 注释
  • YAML
  • XML
  • PHP
12 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
/ / src / AppBundle /实体/ Service.php名称空间AppBundle\实体使用学说\ORM\映射作为ORM使用ob娱乐下载\\学说\验证器\约束\UniqueEntity/ * * *@ORM* \实体@UniqueEntity(* fields={"host", "port"}, * errorPath="port", * message="此端口已在该主机上使用。"*) */服务/ * * *@ORM\ ManyToOne (targetEntity =“App \实体\主机”)* /公共宿主/ * * *@ORM\列(类型=“整数”)* /公共港口;}

现在,消息将被绑定到港口字段。

ignoreNull

类型布尔默认的真正的

如果此选项设置为真正的,则约束将允许多个实体具有值。如果设置为,只有一个值是允许的-如果第二个实体也有值,验证将失败。

有效载荷

类型混合默认的

此选项可用于将任意特定于领域的数据附加到约束。已配置的有效负载不由Validator组件使用,但其处理完全取决于您。

例如,您可能想使用若干错误级别根据错误的严重程度,在前端以不同的方式呈现失败的约束。

此工作,包括代码示例,是根据创作共用BY-SA 3.0许可证。