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

新手上路,请多包涵

我正在使用 doctrine 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"

原文由 manix 发布,翻译遵循 CC BY-SA 4.0 许可协议

回复
阅读 86
2 个回答

我明白了:这里的技巧是使用 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');

设置隐藏模式以使用只读数组

$settings = $query->getResult(Query::HYDRATE_ARRAY);

显示值:

 echo $settings['desc']['value'];  // prints "bar"

查询生成器

使用 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();

原文由 manix 发布,翻译遵循 CC BY-SA 3.0 许可协议

仅供参考,在您的 EntityRepository 中使用 createQueryBuilder 时,您可以直接指定 INDEX BY 以及别名:

 $this->createQueryBuilder('p', 'p.id')

这避免了在 EntityRepositories 中自动处理的手动处理。

原文由 SMASHED 发布,翻译遵循 CC BY-SA 3.0 许可协议

推荐问题
宣传栏