我为了创建一个模型使用学说2.1 settings
表:
id | arg | value | category
1 | name | foo | general_settings
2 | desc | bar | general_settings
假设我有很多设置不同类别的。 为了得到一个特定的类别我做这样的事情所有的设置:
$q = Doctrine_Query::create()
->from('Setting p')
->where('p.category = ?', $category_name);
一切都在这一点上工作正常。 嗯..为$ 64,000的问题是:确实存在一个数据访问的替代方案,让我读结果如下?
$resultSet = $q->execute();
//the magic here could be use the -arg- column as index
$requested_setting = $resulSet['name']
//print the setting value
echo $requested_setting['value']; //should prints "foo"
//another way
echo $resulSet['desc']['value']; //should prints "bar"
我明白了:这里的技巧是使用INDEX BY
字。
查询类
导入查询类(不总是可选):
use \Doctrine\ORM\Query;
创建查询:
$query = $this->data->em->createQuery('
SELECT s
FROM models\Setting s
INDEX BY s.arg //to set array custom key
WHERE s.category = :category');
$query->setParameter('category', 'general');
设置hidration模式,以便与只读阵列工作
$settings = $query->getResult(Query::HYDRATE_ARRAY);
显示值:
echo $settings['desc']['value']; // prints "bar"
QueryBuilder的
随着QueryBuilder
对象,你可以在设置索引from
语句:
$qb = $em->createQueryBuilder();
$qb->select('s');
$qb->from('models\Settings', 's', 's.arg'); // here the magic
$result = $qb->getQuery()->getResult();
然后,您可以访问对象为:
$description = $result['desc'];
$value = $description->getValue();
FYI在EntityRepository使用createQueryBuilder的时候,你可以直接指定INDEX通过与别名一起:
$this->createQueryBuilder('p', 'p.id')
这避免了处理手动从以EntityRepositories被自动处理。