man*_*nix 19 php doctrine multidimensional-array doctrine-orm
我正在使用doctrine 2.1来创建settings表的模型:
id | arg | value | category
1 | name | foo | general_settings
2 | desc | bar | general_settings
Run Code Online (Sandbox Code Playgroud)
假设我有很多不同类别的设置.为了获得特定类别的所有设置,我执行以下操作:
$q = Doctrine_Query::create()
->from('Setting p')
->where('p.category = ?', $category_name);
Run Code Online (Sandbox Code Playgroud)
此时一切正常.好吧.. $ 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"
Run Code Online (Sandbox Code Playgroud)
man*_*nix 58
我明白了:这里的诀窍是使用这个INDEX BY词.
导入Query类(不总是可选的):
use \Doctrine\ORM\Query;
Run Code Online (Sandbox Code Playgroud)
创建查询:
$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');
Run Code Online (Sandbox Code Playgroud)
设置hidration模式以使用只读数组
$settings = $query->getResult(Query::HYDRATE_ARRAY);
Run Code Online (Sandbox Code Playgroud)
显示值:
echo $settings['desc']['value']; // prints "bar"
Run Code Online (Sandbox Code Playgroud)
使用该QueryBuilder对象,您可以在from语句中设置索引:
$qb = $em->createQueryBuilder();
$qb->select('s');
$qb->from('models\Settings', 's', 's.arg'); // here the magic
$result = $qb->getQuery()->getResult();
Run Code Online (Sandbox Code Playgroud)
然后,您可以访问该对象:
$description = $result['desc'];
$value = $description->getValue();
Run Code Online (Sandbox Code Playgroud)
SMA*_*HED 13
在您的EntityRepository中使用createQueryBuilder时,您可以直接指定INDEX BY和别名:
$this->createQueryBuilder('p', 'p.id')
Run Code Online (Sandbox Code Playgroud)
这样可以避免手动处理EntityRepositories中自动处理的内容.
| 归档时间: |
|
| 查看次数: |
26068 次 |
| 最近记录: |