在列号中使用列值作为数组索引

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的

使用该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)

  • 如果您只查询特定字段,例如`SELECT s.arg FROM [...] INDEX BY s.id`*,请不要忘记添加您想要索引的字段*.例如,如果你想用`s.id`索引,请使用`SELECT s.id,s.arg FROM [...] INDEX BY s.id`.否则,Doctrine将不会在其结果行中包含索引值,因此查询的结果将是常规索引数组而不是关联数组. (9认同)
  • 你正逐渐爱上QueryBuilder解决方案.无法在Doctrine文档中找到它...感谢分配:) (4认同)

SMA*_*HED 13

在您的EntityRepository中使用createQueryBuilder时,您可以直接指定INDEX BY和别名:

$this->createQueryBuilder('p', 'p.id')
Run Code Online (Sandbox Code Playgroud)

这样可以避免手动处理EntityRepositories中自动处理的内容.