比较日期是不需要通过int类型的,可以用to_date函数,如果你的日期格式是固定的,那么可以to_date('2011-10-21','yyyy-mm-dd') ,比如A,B两个字段都是格式固定的Varchar2型日期值,那么,比较日期可以用如下语句
select * from 表名 where to_date(A,'yyyy-mm-dd') -to_date(B,'yyyy-mm-dd') >180
oracle环境下测试通过
SELECT COUNT(*) AS "几位同学", SUM(L2.SCORE) "分值之和"
FROM (select DISTINCT L1.NAME, L1.SCORE
FROM (SELECT TA.*
FROM TA
WHERE to_date(DECODE(TA.DATEB,
'null',
TO_CHAR(SYSDATE, 'YYYY/MM/DD'),
TA.DATEB),
'yyyy-mm-dd hh24:mi:ss') -
to_date(DECODE(TA.DATEA,
'null',
TO_CHAR(SYSDATE, 'YYYY/MM/DD'),
TA.DATEA),
'yyyy-mm-dd hh24:mi:ss') > 180) L1) L2
建表语句:
Create table
create table TA
(
ID VARCHAR2(10) default '' not null,
NAME VARCHAR2(20) default '' not null,
DATEA VARCHAR2(20) ,
DATEB VARCHAR2(20) ,
SCORE VARCHAR2(20)
)
tablespace USERS
pctfree 10
initrans 1
maxtrans 255
storage
(
initial 64
minextents 1
maxextents unlimited
);
-- Add comments to the table
comment on table TA
is 'TEST';
-- Add comments to the columns
如果格式固定,是很简单的
to_date('2011-10-21','yyyy-mm-dd')
CONVERT(int,to_date('2011-11-22','yyyy-mm-dd') )