所以,我在连接到不同引擎(MySql、Oracle、PostgreSQL 和 MS SQL)的项目中有 Hibernate 5.3.1,所以我不能使用 native 查询。
假设我在一个表中有 3 条记录,它们都具有相同的日期时间,但我需要仅按日期(而不是时间)对它们进行分组。 例如,2019-12-04;
我执行这个查询:
SELECT
CONCAT(year(tx.date_), month(tx.date_), day(tx.date_)),
iss.code,
COUNT(tx.id)
FROM
tx_ tx
JOIN
issuer_ iss
ON
tx.id_issuer = iss.id
GROUP BY
CONCAT(year(tx.date_), month(tx.date_), day(tx.date_)), iss.code
但是,当我测试它连接到 SQL SERVER 2017 时,它没有返回 20191204,而是返回 2035。在 Oracle 和 MySQL 中运行良好。
有人知道为什么会这样吗?我尝试了不同的方法,比如使用 + 而不是 CONCAT 但结果是一样的。
我也尝试过单独提取它们(不使用 concat),并且它们一直在正确返回。问题是,我需要按完整日期对它们进行分组。
只是为了记录,该字段在 DDBB 中声明为 datetime2
请您参考如下方法:
如何简单地添加它们,而不是使用 CONCAT
。
(year(tx.date_)*10000 + month(tx.date_)*100 + day(tx.date_)*1) AS datenum
因此,试试这个:
SELECT
CAST((year(tx.date_)*10000 + month(tx.date_)*100 + day(tx.date_)*1) AS string) AS datenum,
iss.code
FROM tx_ tx
JOIN issuer_ iss
ON tx.id_issuer = iss.id
GROUP BY year(tx.date_), month(tx.date_), day(tx.date_), iss.code