可用自带函数month来实现。
如:
创建表及插入数据:
create table test(id int,
begindate datetime)
insert into test values (1,'2015-01-01')
insert into test values (2,'2015-02-01')
执行sql语句:
select id,MONTH(begindate) as month from test结果:
1、创建测试表,
create table test_date(id varchar2(20), v_date date);
2、插入测试数据
insert into test_date values(1, sysdate-30);
insert into test_date values(2, sysdate-40);
insert into test_date values(3, sysdate-60);
insert into test_date values(4, sysdate-80);
insert into test_date values(5, sysdate-90);
commit;
3、查询表中全量数据,select t, rowid from test_date t;
4、编写sql,查询指定月份之前的几个月;例如,查询当前时间前两个月的数据;
select t from test_date t where to_char(v_date,'yyyymm') = to_char(add_months(sysdate,-2), 'yyyymm');
在sql中怎样截取时间?
把日期截取为月份有以下几种办法:
1、日期为日期格式,这种最简单,使用Month()函数即可获取月份,如:
1
select month(getdate()) from dual
2、日期为yyyy-mm-dd格式的文本,这种情况下需要转换成日期格式再截取,如:
1
select TO_CHAR(to_date('2013-01-01', 'yyyy-MM-dd'), 'yyyyMM') dateStr from dual
3、日期格式为其他格式,如yyyymmdd或yyyy/mm/dd的,此类格式类似第二种格式可以用类似的语句进行查询,只是转换成日期的时候的格式不一样。
注:以上SQL均基于ORACLE数据库
以上就是关于如何提取sql中日期月份全部的内容,包括:如何提取sql中日期月份、sql查询指定月份之前的几个月、在sql中怎样截取时间等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)