Mysql - 有可能使用Group By semester吗?

问题描述 投票:2回答:3

我需要在查询中每学期使用一个组。有人知道这样做吗?

如果我使用:

 `HAVING Date Between '2012-01 'and '2012-06'`

我相信它会起作用,但不会是查询的正确结果。

任何帮助表示赞赏

mysql date group-by
3个回答
5
投票

你可以用这个 -

+------+------------+
| id   | date       |
+------+------------+
| 1    | 2012-08-14 |
| 2    | 2012-09-20 |
| 3    | 2012-05-14 |
| 4    | 2012-05-08 |
| 5    | 2012-08-16 |
+------+------------+

INSERT INTO table_name VALUES 
  (1, '2012-08-14'),
  (2, '2012-09-20'),
  (3, '2012-05-14'),
  (4, '2012-05-08'),
  (5, '2012-08-16');

SELECT
  YEAR(date) year,
  IF(MONTH(date) < 7, 1, 2) semester,
  COUNT(*)
FROM
  table_name
GROUP BY
  year, semester;

+------+----------+----------+
| year | semester | COUNT(*) |
+------+----------+----------+
| 2012 |        1 |        2 |
| 2012 |        2 |        3 |
+------+----------+----------+

使用HAVING子句 -

SELECT
  YEAR(date) year,
  IF(MONTH(date) < 7, 1, 2) semester,
  COUNT(*)
FROM
  table_name
GROUP BY
  year, semester
HAVING
  semester = 1

+------+----------+----------+
| year | semester | COUNT(*) |
+------+----------+----------+
| 2012 |        1 |        2 |
+------+----------+----------+

0
投票

我设法解决了仅获得第一学期或第二学期的问题,如下所示。

只获得第一学期:

SELECT
  YEAR(date) year,
  IF(MONTH(date) < 7, 1, 2) semester,
  COUNT(*)
FROM
  table_name
WHERE 
  MONTH(date) NOT IN(7,8,9,10,11,12)    
GROUP BY
  year, semester;

感谢所有帮助。


0
投票

您无法获得任何日期学期:

FLOOR( ( MONTH(date)-1) / 6 ) + 1
© www.soinside.com 2019 - 2024. All rights reserved.