本文整理汇总了PHP中Sonata\AdminBundle\Datagrid\ProxyQueryInterface::expr方法的典型用法代码示例。如果您正苦于以下问题:PHP ProxyQueryInterface::expr方法的具体用法?PHP ProxyQueryInterface::expr怎么用?PHP ProxyQueryInterface::expr使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Sonata\AdminBundle\Datagrid\ProxyQueryInterface
的用法示例。
在下文中一共展示了ProxyQueryInterface::expr方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: filter
/**
* @param ProxyQueryInterface $queryBuilder
* @param string $alias
* @param string $field
* @param string $data
*
* @return
*/
public function filter(ProxyQueryInterface $queryBuilder, $name, $field, $data)
{
if (!$data || !is_array($data) || !array_key_exists('value', $data)) {
return;
}
$data['value'] = trim($data['value']);
if (strlen($data['value']) == 0) {
return;
}
$data['type'] = isset($data['type']) && !empty($data['type']) ? $data['type'] : ChoiceType::TYPE_CONTAINS;
$obj = $queryBuilder;
if ($this->condition == self::CONDITION_OR) {
$obj = $queryBuilder->expr();
}
if ($data['type'] == ChoiceType::TYPE_EQUAL) {
$obj->field($field)->equals($data['value']);
} elseif ($data['type'] == ChoiceType::TYPE_CONTAINS) {
$obj->field($field)->equals(new \MongoRegex(sprintf('/%s/i', $data['value'])));
} elseif ($data['type'] == ChoiceType::TYPE_NOT_CONTAINS) {
$obj->field($field)->not(new \MongoRegex(sprintf('/%s/i', $data['value'])));
}
if ($this->condition == self::CONDITION_OR) {
$queryBuilder->addOr($obj);
}
$this->active = true;
}
示例2: configureQuery
public function configureQuery(AdminInterface $admin, ProxyQueryInterface $query, $content = 'list')
{
if ($admin instanceof ContactAdmin) {
$query->andWhere($query->expr()->eq('o.organization', ':org_id'))->andWhere(':school_id MEMBER OF o.schools')->setParameter(':org_id', $this->session->get($this->orgSessionKey))->setParameter(':school_id', $this->session->get($this->schoolSessionKey));
} else {
$query->innerJoin('o.contact', 'c', 'WITH', 'c.organization = :org_id AND :school_id MEMBER OF c.schools')->setParameter(':org_id', $this->session->get($this->orgSessionKey))->setParameter(':school_id', $this->session->get($this->schoolSessionKey));
}
}
示例3: preBatchAction
public function preBatchAction($actionName, ProxyQueryInterface $query, array &$idx, $allElements)
{
if ($actionName == 'delete') {
$query->andWhere($query->expr()->in('o.id', '?1'))->setParameter(1, $idx);
$serviceGroups = $query->execute();
foreach ($serviceGroups as $serviceGroup) {
$this->preRemove($serviceGroup);
}
}
}
示例4: configureQuery
public function configureQuery(AdminInterface $admin, ProxyQueryInterface $query, $content = 'list')
{
$query->andWhere($query->expr()->eq('o.organization', ':org_id'))->setParameter(':org_id', $this->session->get($this->sessionKey));
}