首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >按一岁以上分组

按一岁以上分组
EN

Stack Overflow用户
提问于 2013-07-22 18:05:24
回答 1查看 58关注 0票数 0

我有一个文件列表,我正在使用dotrine和symfony,我希望显示存档产品的列表:

代码语言:javascript
复制
   $query = Doctrine::getTable('Product')
            ->createQuery('a')
            ->select('a.created_at, YEAR(a.created_at) as year, MONTH(a.created_at) as month')
            ->groupBy('year, month')
            ->orderBy('a.created_at DESC')
            ->setHydrationMode(Doctrine_Core::HYDRATE_ARRAY)
            ->execute();

所以我希望更改查询,那么什么时候超过1年,它应该按年分组添加产品吗?

编辑

我补充了这一点,但我想它不适用于学说1:

代码语言:javascript
复制
->andWhere("year <= DATE_ADD(CURRENT_DATE(), 1, 'YEAR')")

我知道这个错误:

代码语言:javascript
复制
SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '1, 'YEAR')
EN

回答 1

Stack Overflow用户

发布于 2013-07-22 18:30:15

我认为您无法在一个选择中定义不同的groupBy子句。但是,您可以执行以下操作之一:

(1)构建了2个独立的查询--一个用于>1年,另一个用于<1年。然后,由于您是水化数组无论如何合并您的数组使用array_merge

(2)使用SQL UNION合并两个查询的结果。不幸的是,doctrine2不支持UNION,所以您需要回到标准SQL (参见这里)

剩下的唯一一点是,如果希望这两个查询的结果看起来相同,则需要在“大于1年”的查询中为这个月添加一个默认值。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17794357

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档