Oracle关于统计每天数据的总和时出现无效数字问题

本文介绍了一种在Oracle数据库中解决非日期格式字段查询的方法。针对VARCHAR2类型的日期字段,通过TO_DATE函数进行正确转换,并按日期进行分组和排序,最终成功获取了每日的数据汇总。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先,要求是,知道这个月数据总数,但是想知道每天分别的数据总数,先上表的字段结构:

desc test1
名称            空值 类型             
------------- -- -------------- 
ID               NUMBER         
INC_DATETIME     VARCHAR2(19)   ---------------------------这个是插入时间,是varchar2格式,这个是问题关键点
RANDOM_ID        NUMBER         
RANDOM_STRING    VARCHAR2(4000) 

然后按照INC_DATETIME 查询每天的数据的综合,但是不得结果,SQL语句是:

select 
  to_char(INC_DATETIME ,'yyyyMMdd'),
  count(id) 
from 
  test1 m 
group by 
  to_char(INC_DATETIME ,'yyyyMMdd')
order by 
  to_char(INC_DATETIME ,'yyyyMMdd'); 

提示的错误为:


ORA-01722: 无效数字
01722. 00000 -  "invalid number"
*Cause:    
*Action:


显示无效数字,就是因为INC_DATETIME不是date类型,需要转换为date类型才行,最后修改一下sql语句:

select 
  to_char(to_date(m.INC_DATETIME,'yyyy-MM-dd hh24:mi:ss'),'yyyyMMdd'),
  count(id) 
from 
  test1 m 
group by 
  to_char(to_date(m.INC_DATETIME,'yyyy-MM-dd hh24:mi:ss'),'yyyyMMdd')
order by 
  to_char(to_date(m.INC_DATETIME,'yyyy-MM-dd hh24:mi:ss'),'yyyyMMdd'); 

这样子才得正确的结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值