如何在hana中格式化日期

Jun*_*uny 4 date-format hana

我需要在我的 hana sql 中格式化日期,但我不知道如何。像这样的东西:

 SELECT
 DATE_FORMAT(DATAS,'%Y-%m') as Dat 
,sum(SALES_VALUE) as Venda
,sum(SALES_QTY) as Qtd
,sum(SALES_VALUE) / sum(SALES_QTY) as  Preco
FROM looqdata.data_store_sales as s
inner join
looqdata.data_store_cad as c
on s.STORE_CODE = c.STORE_CODE
where 1=1
and DATAS between '2016-01-04' and '2016-02-10'
and s.STORE_CODE in  (1,2) 
group by DATE_FORMAT(DATAS,'%Y-%m') 
Run Code Online (Sandbox Code Playgroud)

Lar*_*Br. 7

SAP HANA 中的日期数据类型,就像在大多数其他 DBMS 中一样,没有与之关联的特定格式。格式设置是输出渲染过程的一部分,区域相关设置通常在这里发挥作用。你可以查看我的博客

如果要强制使用特定格式并接受数据类型变为字符串数据类型,则可以使用TO_VARCHAR() 参考文档链接等转换函数。

例如

SELECT 
      TO_VARCHAR (TO_DATE('2009-12-31'), 'YYYY/MM/DD') "to varchar" 
FROM DUMMY;
Run Code Online (Sandbox Code Playgroud)

将日期字符串从格式转换YYYY-MM-DD为日期格式YYYY/MM/DD


Era*_*per 5

正如 Lars 所解释的,您可以使用 TO_VARCHAR() 函数将日期表达式转换为所需的格式

如果要转换数据类型为 DATE 的列中已有的日期,则不需要额外的 TO_DATE() 转换 在这种情况下,可以直接在 SQLScript 中使用 TO_VARCHAR() 进行日期格式转换

请在您的开发 SAP HANA 数据库上检查以下 SQLScript 代码

create column table ProductValue (
Product      varchar(10),
Date     date,
Value  int
);
insert into ProductValue values ('P1','20171001',10);

select *, TO_VARCHAR(Date,'DD.MM.YY')  from ProductValue;
select *, TO_VARCHAR(Date,'DD.MM.YYYY')  from ProductValue;
select *, TO_VARCHAR(Date,'YYYY-MM')  from ProductValue;
select *, TO_VARCHAR(Date,'YYYY-MM-DD')  from ProductValue;
select *, TO_VARCHAR(Date,'YYYY/MM/DD')  from ProductValue;
select *, TO_VARCHAR(TO_DATE(Date),'YYYY/MM/DD')  from ProductValue;
Run Code Online (Sandbox Code Playgroud)