繁体   English   中英

我需要从 dateColumn 获取月份和年份

[英]I need to get month and year from dateColumn

我坚持查询的这一部分,我只需要从我的表中获取月份和年份。

为了说明上下文,我尝试使用“TRUNC_DATE”,Oracle 给我返回类似 ORA-00904 的错误:“DATE_TRUNC”:无效标识符 sql 这条查询是从 Udacity 获取的,但在 sql 中,开发人员看起来好像没有不工作。

当我尝试更深入地搜索时,我发现类似 convert(char(7), ia.invoice_date(), 120) yearMonth 的内容,它仍然无法正常工作并且返回错误。 ORA-00936: 缺少表达式

我尝试了很多方法但没有解决方案。

如果任何人有什么可以帮助的想法,我将不胜感激。

在下面,我粘贴了查询的片段以获取指南帮助:

SELECT 
COUNT(ia.invoice_id) total_de_facturas,
SUM(ia.invoice_amount) monto_total,
convert(char(7), ia.invoice_date(), 120) yearMonth

FROM AP.ap_invoices_all ia GROUP BY ia.vendor_id;

您将 Oracle 语法与 Postgres ( date_trunc() ) 和 SQL 服务器 ( convert() ) 混合使用。 许多日期函数是特定于供应商的,因此您需要了解数据库的相关语法。

在 Oracle 中,您将使用trunc()将日期截断为该月的第一天:

trunc(ia.invoice_date, 'mm')

使用 EXTRACT function,尝试这些来测试它是如何工作的,并在您的查询中使用它 -

SELECT EXTRACT(YEAR FROM DATE '2020-03-07') FROM DUAL;
SELECT EXTRACT(MONTH FROM DATE '2020-03-07') FROM DUAL;

如果您想要一个 YYYY-MM 格式的字符串值——这似乎是 120 样式和 SQL 服务器语法convert()调用中的char(7)的意图——那么您可以使用该格式的to_char() model:

to_char(ia.invoice_date, 'YYYY-MM') as yearMonth

您不需要截断到本月的第一天,因为无论如何您都会丢弃一天的部分。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM