本文整理汇总了PHP中Symfony\Component\Validator\Constraint::getDbOptions方法的典型用法代码示例。如果您正苦于以下问题:PHP Constraint::getDbOptions方法的具体用法?PHP Constraint::getDbOptions怎么用?PHP Constraint::getDbOptions使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Symfony\Component\Validator\Constraint
的用法示例。
在下文中一共展示了Constraint::getDbOptions方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: validate
public function validate($value, Constraint $constraint)
{
if (!$constraint instanceof UniqueInDb) {
throw new UnexpectedTypeException($constraint, get_class(new UniqueInDb()));
}
/* @var $constraint UniqueInDb */
$config = $constraint->getDbOptions();
// 'em' => $this->container->get('doctrine.orm.entity_manager'),
// 'table' => 'users',
// 'field' => 'email'
$query = "\nSELECT count(*) c\nFROM {$config['table']}\nWHERE {$config['field']} = :value\n";
$stmt = $config['em']->getConnection()->prepare($query);
$stmt->bindValue('value', $value);
$stmt->execute();
$c = 1;
if ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
$c = (int) $row['c'];
}
if ($c) {
$this->buildViolation($constraint->message)->setParameter('{{ unique }}', $value)->setInvalidValue($value)->setCode(UniqueInDb::NOT_UNIQUE)->addViolation();
}
}