oracle时间函数(求每月第一天等等等)
ORACLE时间常用函数(字段取年、月、日、季度)
ORACLE时间常⽤函数(字段取年、⽉、⽇、季度)TO_DATE格式Day:dd number 12dy abbreviated friday spelled out fridayddspth spelled out, ordinal twelfthMonth:mm number 03mon abbreviated marmonth spelled out marchYear:yy two digits 98yyyy four digits 199824⼩时格式下时间范围为: 0:00:00 - 23:59:59.... 12⼩时格式下时间范围为: 1:00:00 - 12:59:59 ....Y或YY或YYY 年的最后⼀位,两位或三位Select to_char(sysdate,’YYY’) from dual;002表⽰2002年SYEAR或YEAR SYEAR使公元前的年份前加⼀负号Select to_char(sysdate,’SYEAR’) from dual; -1112表⽰公元前111 2年Q 季度,1~3⽉为第⼀季度 Select to_char(sysdate,’Q’) from dual; 2表⽰第⼆季度①MM ⽉份数 Select to_char(sysdate,’MM’) from dual; 12表⽰12⽉RM ⽉份的罗马表⽰ Select to_char(sysdate,’RM’) from dual; IV表⽰4⽉Month ⽤9个字符长度表⽰的⽉份名 Select to_char(sysdate,’Month’) from dual; May后跟6个空格表⽰5⽉WW 当年第⼏周 Select to_char(sysdate,’WW’) from dual; 24表⽰2002年6⽉13⽇为第24周W 本⽉第⼏周 Select to_char(sysdate,’W’) from dual; 2002年10⽉1⽇为第1周DDD 当年第⼏, 1⽉1⽇为001,2⽉1⽇为032 Select to_char(sysdate,’DDD’) from dual; 363 2002年1 2⽉2 9⽇为第363天DD 当⽉第⼏天 Select to_char(sysdate,’DD’) from dual; 04 10⽉4⽇为第4天D 周内第⼏天 Select to_char(sysdate,’D’) from dual; 5 2002年3⽉14⽇为星期⼀DY 周内第⼏天缩写 Select to_char(sysdate,’DY’) from dual; SUN 2002年3⽉24⽇为星期天HH或HH12 12进制⼩时数 Select to_char(sysdate,’HH’) from dual;02 午夜2点过8分为02 HH24 24⼩时制 Select to_char(sysdate,’HH24’) from dual; 14 下午2点08分为14MI 分钟数(0~59) Select to_char(sysdate,’MI’) from dual; 17下午4点17分SS 秒数(0~59) Select to_char(sysdate,’SS’) from dual; 22 11点3分22秒提⽰注意不要将MM格式⽤于分钟(分钟应该使⽤MI)。
Oracle日期函数和循环总结
Oracle⽇期函数和循环总结⼀,⽇期相关的函数Select to_char(sysdate,'Q') from dual;--指定⽇期的季度Select to_char(sysdate,'MM') from dual;--⽉份Select to_char(sysdate,'WW') from dual;--当年第⼏周Select to_char(sysdate,'W') from dual ;--本⽉第⼏周Select to_char(sysdate,'DD') from dual;--当⽉第⼏天Select to_char(sysdate,'D') from dual;--周内第⼏天Select to_char(sysdate,'DY') from duaL;--星期⼏Select last_day(sysdate) from dual;--本⽉最后⼀天Select add_months(sysdate,2) from dual;--当前⽇期d后推n个⽉select months_between(sysdate,to_date('2012-11-12','yyyy-mm-dd'))from dual;--⽇期f和s间相差⽉数SELECT (next_day(sysdate,1)+1) FROM dual;--指定的⽇期之后的第⼀个⼯作⽇的⽇期select to_char(add_months(last_day(sysdate),-1),'yyyy-MM-dd') LastDay from dual;--上⽉末天select to_char(add_months(sysdate,-1),'yyyy-MM-dd') PreToday from dual;--上⽉今天select to_char(add_months(last_day(sysdate)+1,-2),'yyyy-MM-dd') firstDay from dual;--上⽉第⼀天select to_char(sysdate,'ww') from dual group by to_char(sysdate,'ww');--按照每周进⾏统计select to_char(sysdate,'mm') from dual group by to_char(sysdate,'mm');--按照每⽉进⾏统计select to_char(sysdate,'q') from dual group by to_char(sysdate,'q');--按照每季度进⾏统计⼆,循环编写循环控制结构时,⽤户可以使⽤基本循环,WHILE循环和FOR循环等三种类型的循环语句,下⾯分别介绍使⽤这三种循环语句的⽅法。
Oracle日期函数大全
ORACLE日期时间函数大全TO_DATE格式(以时间:2007-11-02 13:45:25为例)Year:yy two digits 两位年显示值:07yyy three digits 三位年显示值:007yyyy four digits 四位年显示值:2007Month:mm number 两位月显示值:11mon abbreviated 字符集表示显示值:11月,若是英文版,显示novmonth spelled out 字符集表示显示值:11月,若是英文版,显示novemberDay:dd number 当月第几天显示值:02ddd number 当年第几天显示值:02dy abbreviated 当周第几天简写显示值:星期五,若是英文版,显示friday spelled out 当周第几天全写显示值:星期五,若是英文版,显示fridayddspth spelled out, ordinal twelfthHour:hh two digits 12小时进制显示值:01hh24 two digits 24小时进制显示值:13Minute:mi two digits 60进制显示值:45Second:ss two digits 60进制显示值:25其它Q digit 季度显示值:4WW digit 当年第几周显示值:44W digit 当月第几周显示值:124小时格式下时间范围为:0:00:00 - 23:59:59....12小时格式下时间范围为:1:00:00 - 12:59:59 ....1. 日期和字符转换函数用法(to_date,to_char)select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') as nowTime from dual; //日期转化为字符串select to_char(sysdate,'yyyy') as nowYear from dual; //获取时间的年select to_char(sysdate,'mm') as nowMonth from dual; //获取时间的月select to_char(sysdate,'dd') as nowDay from dual; //获取时间的日select to_char(sysdate,'hh24') as nowHour from dual; //获取时间的时select to_char(sysdate,'mi') as nowMinute from dual; //获取时间的分select to_char(sysdate,'ss') as nowSecond from dual; //获取时间的秒select to_date('2004-05-07 13:23:44','yyyy-mm-dd hh24:mi:ss') from dual//2.select to_char( to_date(222,'J'),'Jsp') from dual显示Two Hundred Twenty-Two3.求某天是星期几select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day') from dual;星期一select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE = American') from dual;monday设置日期语言ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN';也可以这样TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American')4. 两个日期间的天数ceil(n) 取大于等于数值n的最小整数floor(n)取小于等于数值n的最大整数SELECT floor(TO_DATE('2008-05-02 00:00:00', 'yyyy-mm-dd hh24-mi-ss') -TO_DATE('2008-04-30 23:59:59', 'yyyy-mm-dd hh24-mi-ss')) 相差天数FROM DUAL;相差天数1SELECT ceil(TO_DATE('2008-05-02 00:00:00', 'yyyy-mm-dd hh24-mi-ss') -TO_DATE('2008-04-30 23:59:59', 'yyyy-mm-dd hh24-mi-ss')) 相差天数FROM DUAL;相差天数---------25. 时间为null的用法select id, active_date from table1UNIONselect 1, TO_DATE(null) from dual;注意要用TO_DATE(null)6.月份差a_date between to_date('20011201','yyyymmdd') and to_date('20011231','yyyymmdd')那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。
oracle年月日格式
在Oracle数据库中,日期格式可以使用TO_DATE 函数来指定。
以下是一些常见的日期格式化选项:
年月日(YYYY-MM-DD):
TO_DATE('2023-11-13', 'YYYY-MM-DD')
年月日时分秒(YYYY-MM-DD HH24:MI:SS):
TO_DATE('2023-11-13 12:30:45', 'YYYY-MM-DD HH24:MI:SS')
月/日/年(MM/DD/YYYY):
TO_DATE('11/13/2023', 'MM/DD/YYYY')
月-年(Mon-YYYY):
TO_DATE('Nov-2023', 'Mon-YYYY')
时分秒(HH24:MI:SS):
TO_DATE('12:30:45', 'HH24:MI:SS')
这只是一些示例,你可以根据需要调整格式字符串。
在Oracle 中,日期和时间格式模型的元素包括:
YYYY:四位年份
MM:月份(01 到12)
DD:天(01 到31)
HH24:小时(00 到23)
MI:分钟(00 到59)
SS:秒(00 到59)
Mon:缩写的月份名称(例如:Jan,Feb)
YYYY-MM-DD:标准的日期格式
你可以根据需要组合这些元素,创建适合你数据的日期格式。
Oracle各种日期计算方法
)
FROM dual
next_day为计算从指定日期开始的第一个符合要求的日期,这里的'星期一'将根据NLS_DATE_LANGUAGE的设置稍有不同。<br>
去掉时分秒
1
select trunc(sysdate) from dual
取得某个月的天数
1
2
3
4
SELECT trunc(last_day(SYSDATE))-
本月的第一天
1
select to_char(trunc(add_months(last_day(sysdate), -1) + 1), 'yyyy-mm-dd')
本月最后一天
1
select to_char(last_day(sysdate), 'yyyy-mm-dd')
一年的第一天
1
SELECT to_date( to_char(SYSDATE,'yyyy')||'-01-01','yyyy-mm-dd') FROM dual
季度的第一天
1
2
3
4
5
6
SELECT to_date(
to_char(SYSDATE,'yyyy-')||
lpad(floor(to_number(to_char(SYSDATE,'mm'))/3)*3+1,2,'0')||
'-01',
'yyyy-mm-dd')
FROM dual
floor为向下取整
ORACLE日期时间函数大全
ORACLE日期时间函数大全ORACLE日期时间函数大全TO_DATE格式(以时间:2007-11-02 13:45:25为例)Year:yy two digits 两位年显示值:07yyy three digits 三位年显示值:007yyyy four digits 四位年显示值:2007Month:mm number 两位月显示值:11mon abbreviated 字符集表示显示值:11月,若是英文版,显示nov month spelled out 字符集表示显示值:11月,若是英文版,显示novemberDay:dd number 当月第几天显示值:02ddd number 当年第几天显示值:02dy abbreviated 当周第几天简写显示值:星期五,若是英文版,显示friday spelled out 当周第几天全写显示值:星期五,若是英文版,显示fridayddspth spelled out, ordinal twelfthHour:hh two digits 12小时进制显示值:01hh24 two digits 24小时进制显示值:13Minute:mi two digits 60进制显示值:45Second:ss two digits 60进制显示值:25其它Q digit 季度显示值:4WW digit 当年第几周显示值:44W digit 当月第几周显示值:124小时格式下时间范围为: 0:00:00 - 23:59:59....12小时格式下时间范围为: 1:00:00 - 12:59:59 ....1. 日期和字符转换函数用法(to_date,to_char)select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') as nowTime from dual; //日期转化为字符串select to_char(sysdate,'yyyy') as nowYear from dual; //获取时间的年select to_char(sysdate,'mm') as nowMonth from dual; //获取时间的月select to_char(sysdate,'dd') as nowDay from dual; //获取时间的日select to_char(sysdate,'hh24') as nowHour from dual; //获取时间的时select to_char(sysdate,'mi') as nowMinute from dual; //获取时间的分select to_char(sysdate,'ss') as nowSecond from dual; //获取时间的秒select to_date('2004-05-07 13:23:44','yyyy-mm-dd hh24:mi:ss') from dual//2.select to_char( to_date(222,'J'),'Jsp') from dual显示Two Hundred Twenty-Two3.求某天是星期几select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day') from dual;星期一select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE = American') from dual;monday设置日期语言ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN';也可以这样TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American')4. 两个日期间的天数select floor(sysdate - to_date('20020405','yyyymmdd')) from dual;5. 时间为null的用法select id, active_date from table1UNIONselect 1, TO_DATE(null) from dual;注意要用TO_DATE(null)6.月份差a_date between to_date('20011201','yyyymmdd') and to_date('20011231','yyyymmdd')那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。
Oracle时间函数
常用日期型函数1。
Sysdate 当前日期和时间SQL> Select sysdate from dual;SYSDATE----------21-6月 -052。
Last_day 本月最后一天SQL> Select last_day(sysdate) from dual;LAST_DAY(S----------30-6月 -053。
Add_months(d,n) 当前日期d后推n个月用于从一个日期值增加或减少一些月份date_value:=add_months(date_value,number_of_months)SQL> Select add_months(sysdate,2) from dual;ADD_MONTHS----------21-8月 -054。
Months_between(f,s) 日期f和s间相差月数SQL> select months_between(sysdate,to_date('2005-11-12','yyyy-mm-dd'))from dual;MONTHS_BETWEEN(SYSDATE,TO_DATE('2005-11-12','YYYY-MM-DD'))-----------------------------------------------------------4.69667415。
NEXT_DAY(d, day_of_week)返回由"day_of_week"命名的,在变量"d"指定的日期之后的第一个工作日的日期。
参数"day_of_week"必须为该星期中的某一天。
SQL> SELECT next_day(to_date('20050620','YYYYMMDD'),1) FROM dual;NEXT_DAY(T----------26-6月 -056。
oracle 取时间差 Oracle函数大全
MONTHS_BETWEEN(SYSDATE,TO_DATE('2005-11-12','YYYY- MM-DD'))
-------------------------------------------------- --------
-4.6966741
5。NEXT_DAY(d, day_of_week)
返回由"day_of_week"命名的,在变量"d"指定的日期之后的第一个工作日的日期。参数"day_of_week"必须为该星期中的某一天。
SQL> SELECT next_day(to_date('20050620','YYYYMMDD'),1) FROM dual;
NEXT_DAY(T
SS 秒数(0~59) Select to_char(sysdate,’SS’) from dual; 22 11点3分22秒
提示注意不要将MM格式用于分钟(分钟应该使用MI)。MM是用于月份的格式,将它用于分钟也能工作,但结果是错误的。
现在给出一些实践后的用法:
1。上月末天:
常用日期数据格式(该段为摘抄)
Y或YY或YYY 年的最后一位,两位或三位 Select to_char(sysdate,’YYY’) from dual; 002表示2002年
SYEAR或YEAR SYEAR使公元前的年份前加一负号 Select to_char(sysdate,’SYEAR’) from dual; -1112表示公元前111 2年
and trim(to_char(t.d, 'Day')) = '星期五'
Oracle常用函数
Oracle常用函数sysdate为系统日期 dual为虚表一)日期函数[重点掌握前四个日期函数]1,add_months[返回日期加(减)指定月份后(前)的日期]select sysdate S1,add_months(sysdate,10) S2,add_months(sysdate,5) S3 from dual;2,last_day [返回该月最后一天的日期]select last_day(sysdate) from dual;3,months_between[返回日期之间的月份数]select sysdate S1, months_between('1-4月-04',sysdate) S2,months_between('1-4月-04','1-2月-04') S3 from dual4,next_day(d,day): 返回下个星期的日期,day为1-7或星期日-星期六,1表示星期日select sysdate S1,next_day(sysdate,1) S2,next_day(sysdate,'星期日') S3 FROM DUAL5,round[舍入到最接近的日期](day:舍入到最接近的星期日)select sysdate S1,round(sysdate) S2 ,round(sysdate,'year') YEAR,round(sysdate,'month') MONTH ,round(sysdate,'day') DAY from dual6,trunc[截断到最接近的日期]select sysdate S1,trunc(sysdate) S2,trunc(sysdate,'year') YEAR,trunc(sysdate,'month') MONTH ,trunc(sysdate,'day') DAY from dual7,返回日期列表中最晚日期select greatest('01-1月-04','04-1月-04','10-2月-04') from dual二)字符函数(可用于字面字符或数据库列)1,字符串截取select substr('abcdef',1,3) from dual2,查找子串位置select instr('abcfdgfdhd','fd') from dual3,字符串连接select 'HELLO'||'hello world' from dual;4, 1)去掉字符串中的空格select ltrim(' abc') s1,rtrim('zhang ') s2,trim(' zhang ') s3 from dual2)去掉前导和后缀select trim(leading 9 from 9998767999) s1,trim(trailing 9 from 9998767999) s2,trim(9 from 9998767999) s3 from dual;5,返回字符串首字母的Ascii值select ascii('a') from dual6,返回ascii值对应的字母select chr(97) from dual7,计算字符串长度select length('abcdef') from dual8,initcap(首字母变大写) ,lower(变小写),upper(变大写)select lower('ABC') s1,upper('def') s2,initcap('efg') s3 from dual;9,Replaceselect replace('abc','b','xy') from dual;10,translateselect translate('abc','b','xx') from dual; -- x是1位11,lpad [左添充] rpad [右填充](用于控制输出格式)select lpad('func',15,'=') s1, rpad('func',15,'-') s2 from dual; select lpad(dname,14,'=') from dept;12, decode[实现if ..then 逻辑]select deptno,decode(deptno,10,'1',20,'2',30,'3','其他') from dept; 三)数字函数1,取整函数(ceil 向上取整,floor 向下取整)select ceil(66.6) N1,floor(66.6) N2 from dual;2, 取幂(power) 和求平方根(sqrt)select power(3,2) N1,sqrt(9) N2 from dual;3,求余select mod(9,5) from dual;4,返回固定小数位数 (round:四舍五入,trunc:直接截断)select round(66.667,2) N1,trunc(66.667,2) N2 from dual;5,返回值的符号(正数返回为1,负数为-1)select sign(-32),sign(293) from dual;四)转换函数1,to_char()[将日期和数字类型转换成字符类型]1) select to_char(sysdate) s1,to_char(sysdate,'yyyy-mm-dd') s2,to_char(sysdate,'yyyy') s3,to_char(sysdate,'yyyy-mm-dd hh12:mi:ss') s4,to_char(sysdate, 'hh24:mi:ss') s5,to_char(sysdate,'DAY') s6 from dual;2) select sal,to_char(sal,'$99999') n1,to_char(sal,'$99,999') n2 from emp2, to_date()[将字符类型转换为日期类型]insert into emp(empno,hiredate)values(8000,to_date('2004-10-10','yyyy-mm-dd'));3, to_number() 转换为数字类型select to_number(to_char(sysdate,'hh12')) from dual; //以数字显示的小时数五)其他函数user:返回登录的用户名称select user from dual;vsize:返回表达式所需的字节数select vsize('HELLO') from dual;nvl(ex1,ex2):ex1值为空则返回ex2,否则返回该值本身ex1(常用)例:如果雇员没有佣金,将显示0,否则显示佣金select comm,nvl(comm,0) from emp;nullif(ex1,ex2):值相等返空,否则返回第一个值例:如果工资和佣金相等,则显示空,否则显示工资select nullif(sal,comm),sal,comm from emp;coalesce:返回列表中第一个非空表达式select comm,sal,coalesce(comm,sal,sal*10) from emp;nvl2(ex1,ex2,ex3) :如果ex1不为空,显示ex2,否则显示ex3如:查看有佣金的雇员姓名以及他们的佣金select nvl2(comm,ename,') as HaveCommName,comm from emp;六)分组函数max min avg count sum1,整个结果集是一个组1) 求部门30 的最高工资,最低工资,平均工资,总人数,有工作的人数,工种数量及工资总和select max(ename),max(sal),min(ename),min(sal),avg(sal),count(*) ,count(job),count(distinct(job)) ,sum(sal) from emp where deptno=30;2, 带group by 和 having 的分组1)按部门分组求最高工资,最低工资,总人数,有工作的人数,工种数量及工资总和select deptno, max(ename),max(sal),min(ename),min(sal),avg(sal),count(*) ,count(job),count(distinct(job)) ,sum(sal) from emp group by deptno;2)部门30的最高工资,最低工资,总人数,有工作的人数,工种数量及工资总和select deptno, max(ename),max(sal),min(ename),min(sal),avg(sal),count(*) ,count(job),count(distinct(job)) ,sum(sal) from emp group by deptno having deptno=30;3, stddev 返回一组值的标准偏差select deptno,stddev(sal) from emp group by deptno;variance 返回一组值的方差差select deptno,variance(sal) from emp group by deptno;4, 带有rollup和cube操作符的Group Byrollup 按分组的第一个列进行统计和最后的小计cube 按分组的所有列的进行统计和最后的小计select deptno,job ,sum(sal) from emp group by deptno,job;select deptno,job ,sum(sal) from emp group by rollup(deptno,job); cube 产生组内所有列的统计和最后的小计select deptno,job ,sum(sal) from emp group by cube(deptno,job);。
oracle日期计算
oracle日期计算Oracle数据库中提供了很多日期计算的函数和运算符,可以帮助我们完成各种日期计算操作。
下面详细介绍一些常用的日期计算方法。
1.DATE和TIMESTAMP数据类型在Oracle中,DATE数据类型表示日期和时间,精确到秒;而TIMESTAMP数据类型表示日期和时间,精确到纳秒。
我们可以使用这两种数据类型来表示和计算日期。
2.使用SYSDATE函数获取当前日期和时间SYSDATE函数可以获取当前日期和时间。
例如,可以使用SELECTSYSDATEFROMDUAL;语句来查询当前日期和时间。
3.使用TO_DATE函数将字符串转换为日期TO_DATE函数可以将字符串转换为日期。
例如,使用SELECTTO_DATE('2024-01-01','YYYY-MM-DD')FROMDUAL;语句将字符串'2024-01-01'转换为日期。
4.使用ADD_MONTHS函数添加月份ADD_MONTHS函数可以在一个日期上添加指定的月数。
例如,使用SELECTADD_MONTHS(SYSDATE,1)FROMDUAL;语句可以获取当前日期后一个月的日期。
5.使用MONTHS_BETWEEN计算两个日期之间的月份差MONTHS_BETWEEN函数可以计算两个日期之间的月份差。
例如,使用SELECTMONTHS_BETWEEN(TO_DATE('2024-12-01','YYYY-MM-DD'),TO_DATE('2024-01-01','YYYY-MM-DD'))FROMDUAL;语句可以计算出2024年12月1日与2024年1月1日之间的月份差。
6.使用NEXT_DAY函数查找下一个指定的星期日期NEXT_DAY函数可以查找下一个指定的星期日期。
例如,使用SELECTNEXT_DAY(SYSDATE,'FRIDAY')FROMDUAL;语句可以查找下一个星期五的日期。
oracle中取月初和月末的方法
oracle中取月初和月末的方法在Oracle数据库中,可以使用不同的方法来获取月初和月末的日期。
方法一:使用TRUNC函数和ADD_MONTHS函数```SELECTTRUNC(SYSDATE,'MM')AS"月初日期",TRUNC(ADD_MONTHS(SYSDATE,1),'MM')-1AS"月末日期"FROMDUAL;```方法二:使用LAST_DAY函数和TRUNC函数```SELECTTRUNC(SYSDATE,'MM')AS"月初日期",LAST_DAY(SYSDATE)AS"月末日期"FROMDUAL;```方法三:使用TO_CHAR函数和TO_DATE函数```SELECTTO_DATE(TO_CHAR(SYSDATE,'YYYY-MM'),'-01','YYYY-MM-DD')AS"月初日期",TO_DATE(TO_CHAR(SYSDATE,'YYYY-MM'),'-',TO_CHAR(LAST_DAY(SYSDATE),'DD'),'YYYY-MM-DD')AS"月末日期"FROMDUAL;```方法四:使用EXTRACT函数和TO_CHAR函数```SELECTTO_DATE(TO_CHAR(EXTRACT(YEARFROMSYSDATE)),'-',TO_CHAR(EXTRACT(MONTHFROMSYSDATE),'FM00'),'-01','YYYY-MM-DD')AS"月初日期",TO_DATE(TO_CHAR(EXTRACT(YEARFROMSYSDATE)),'-',TO_CHAR(EXTRACT(MONTHFROMSYSDATE),'FM00'),'-',TO_CHAR(EXTRACT(DAYFROMLAST_DAY(SYSDATE))),'YYYY-MM-DD')AS"月末日期"FROMDUAL;```方法五:使用INTERVAL关键字和TRUNC函数```SELECTTRUNC(SYSDATE,'MM')AS"月初日期",(TRUNC(SYSDATE,'MM')+INTERVAL'1'MONTH)-INTERVAL'1'DAYAS"月末日期"FROMDUAL;```这些方法都能够准确地获取当前日期所在月份的月初和月末日期。
oracle获取本月第一天和最后一天及Oracle trunc()函数的用法
oracle获取本月第一天和最后一天及Oracle trunc()函数的用法select to_char(trunc(add_months(last_day(sysdate), -1) + 1), 'yyyy-mm-dd') "本月第一天",to_char(last_day(sysdate), 'yyyy-mm-dd') "本月最后一天"--Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysdate) from dual --2011-3-18 今天的日期为2011-3-182.select trunc(sysdate, 'mm') from dual --2011-3-1返回当月第一天.3.select trunc(sysdate,'yy') from dual --2011-1-1 返回当年第一天4.select trunc(sysdate,'dd') from dual --2011-3-18 返回当前年月日5.select trunc(sysdate,'yyyy') from dual --2011-1-1 返回当年第一天6.select trunc(sysdate,'d') from dual --2011-3-13 (星期天)返回当前星期的第一天7.select trunc(sysdate, 'hh') from dual --2011-3-18 14:00:00 当前时间为14:418.select trunc(sysdate, 'mi') from dual --2011-3-18 14:41:00 TRUNC()函数没有秒的精确/***************数字********************//*TRUNC(number,num_digits)Number 需要截尾取整的数字。
ORACLE日期函数01 (1)
ORACLE日期时间函数大全TO_DATE格式(以时间:2007-11-02 13:45:25为例)Year:yy two digits 两位年显示值:07yyy three digits 三位年显示值:007yyyy four digits 四位年显示值:2007Month:mm number 两位月显示值:11mon abbreviated 字符集表示显示值:11月,若是英文版,显示novmonth spelled out 字符集表示显示值:11月,若是英文版,显示novemberDay:dd number 当月第几天显示值:02ddd number 当年第几天显示值:02dy abbreviated 当周第几天简写显示值:星期五,若是英文版,显示friday spelled out 当周第几天全写显示值:星期五,若是英文版,显示friday ddspth spelled out, ordinal twelfthHour:hh two digits 12小时进制显示值:01hh24 two digits 24小时进制显示值:13Minute:mi two digits 60进制显示值:45Second:ss two digits 60进制显示值:25其它Q digit 季度显示值:4WW digit 当年第几周显示值:44W digit 当月第几周显示值:124小时格式下时间范围为:0:00:00 - 23:59:59....12小时格式下时间范围为:1:00:00 - 12:59:59 ....1. 日期和字符转换函数用法(to_date,to_char)select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') as nowTime from dual; //日期转化为字符串select to_char(sysdate,'yyyy') as nowYear from dual; //获取时间的年select to_char(sysdate,'mm') as nowMonth from dual; //获取时间的月select to_char(sysdate,'dd') as nowDay from dual; //获取时间的日select to_char(sysdate,'hh24') as nowHour from dual; //获取时间的时select to_char(sysdate,'mi') as nowMinute from dual; //获取时间的分select to_char(sysdate,'ss') as nowSecond from dual; //获取时间的秒select to_date('2004-05-07 13:23:44','yyyy-mm-dd hh24:mi:ss') from dual//2.select to_char( to_date(222,'J'),'Jsp') from dual显示Two Hundred Twenty-Two3.求某天是星期几select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day') from dual;星期一select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE = American') from dual;monday设置日期语言ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN';也可以这样TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American')4. 两个日期间的天数select floor(sysdate - to_date('20020405','yyyymmdd')) from dual;5. 时间为null的用法select id, active_date from table1UNIONselect 1, TO_DATE(null) from dual;注意要用TO_DATE(null)6.月份差a_date between to_date('20011201','yyyymmdd') and to_date('20011231','yyyymmdd') 那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。
Oracle常用日期函数
Oracle常⽤⽇期函数常⽤的时间格式掩码如下:掩码元素含义YYYY 四位数年份(如:2005) yearYY ⼆位数年份(如 05)Q 季度(1-4)MM ⽉份(01-12) monthWW 年的星期数(1-53),其中第⼀星期为年的第⼀天⾄第七天W ⽉的星期数(1-5),其中第⼀星期为⽉的第⼀天⾄第七天DDD 年的⽇(1-366)DD ⽉的⽇(1-31)D 周的⽇(1-7),其中周⽇为1,周六为7 dayHH24 24⼩时制(0-23) hourMI 分钟(0-59) minuteSS 秒(0-59) secondSSSSS ⾃午夜之后的秒(0-86399)两个很不错的函数,可以操作⽇期,也可以操作数值:round(⽇期,'指定的⽇期掩码') 返回⽇期时间的四舍五⼊结果指定的掩码不同则结果结果也不同year 以 7⽉1⽇分界线month 以16号为分界线day 以中午12点为分界线hh 以30分钟为分界线mi 以30秒为分界线trunc(⽇期,'指定的⽇期掩码') 返回截断时间year 本年度的1⽉1⽇month 本⽉的1号例⼦:(注意: day d dd 三者的区别)SQL> select round(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'year') from dual; ROUND(TO_DATE('2007051616:31:4------------------------------2007-1-1SQL> select round(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'month') from dual; ROUND(TO_DATE('2007051616:31:4------------------------------2007-6-1SQL> select round(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'mm') from dual; ROUND(TO_DATE('2007051616:31:4------------------------------2007-6-1SQL> select round(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'day') from dual; ROUND(TO_DATE('2007051616:31:4------------------------------2007-5-20SQL> select round(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'d') from dual; ROUND(TO_DATE('2007051616:31:4------------------------------2007-5-20SQL> select round(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'dd') from dual; ROUND(TO_DATE('2007051616:31:4------------------------------2007-5-17SQL> select trunc(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'year') from dual; TRUNC(TO_DATE('2007051616:31:4------------------------------2007-1-1SQL> select trunc(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'month') from dual;TRUNC(TO_DATE('2007051616:31:4------------------------------2007-5-1SQL> select trunc(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'mm') from dual;TRUNC(TO_DATE('2007051616:31:4------------------------------2007-5-1SQL> select trunc(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'day') from dual;TRUNC(TO_DATE('2007051616:31:4------------------------------2007-5-13SQL> select trunc(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'d') from dual;TRUNC(TO_DATE('2007051616:31:4------------------------------2007-5-13SQL> select trunc(to_date('20070516 16:31:46','yyyymmdd hh24:mi:ss'),'dd') from dual;TRUNC(TO_DATE('2007051616:31:4------------------------------2007-5-16⽇期时间函数:add_months(⽇期,number) 指定⽇期推迟number个⽉last_day(⽇期) 指定⽇期当⽉的最后⼀天new_time(⽇期,时区简写) 调整时区next_day(⽇期,number) number表⽰周⼏,星期⽇是1,指定number的⽇期(⼀周内或⼀周后)months_between(⽇期1,⽇期2) ⽇期1和⽇期2之间有⼏个⽉sysdate 系统当期那⽇期和时间练习时的代码:select to_number(to_char(last_day(add_months(to_date('20040406','yyyymmdd'),-1))+1,'yyyymmdd')) from dual; TO_NUMBER(TO_CHAR(LAST_DAY(ADD------------------------------20040401select to_number(to_char(last_day(to_date('20040406','yyyymmdd')),'yyyymmdd')) from dual;TO_NUMBER(TO_CHAR(LAST_DAY(ADD------------------------------20040430create or replace procedure p_hkb_date_insert is/* 过程功能描述:⽇期插⼊表中*/v_days number(10);v_date date;i number(10);beginbegin--取得当⽉天数select to_number(to_char(last_day(sysdate), 'dd'))into v_daysfrom dual;--select sysdate from dual; 当前⽇期--select last_day(sysdate) from dual; ⽉底⽇期--select last_day(add_months(sysdate, -1)) from dual; 上⽉底⽇期-- SELECT to_char(last_day(SYSDATE),'dd') days FROM dual; 当前⽉的天数--select last_day(add_months(sysdate,-1))+1 from dual; 当前⽉第⼀天--select to_number(to_char(sysdate,'yyyymmdd')) from dual;系统当前⽇期转换成如20070910格式: end;i := 1;beginselect last_day(add_months(sysdate, -1)) into v_date from dual;while i <= v_daysloopinsert into hkb_datevalues(v_date + i,to_char(v_date + i, 'yyyymmdd'),to_number(to_char(v_date + i, 'yyyymmdd')));--insert into hkb_date--(float_date)-- values--(to_char(v_date + i, 'yyyymmdd'));-- insert into hkb_date--(number_date)-- values--(to_number(to_char(v_date + i, 'yyyymmdd')));i := i + 1;end loop;end;end p_hkb_date_insert;create table hkb_date_construct as select * from hkb_date where 1=2; 继承表字段create table hkb_date_data as select * from hkb_date; 继承表记录。
oracle日期函数
oracle⽇期函数oracle⽇期时间的加减法加法select sysdate,add_months(sysdate,12) from dual; --加1年select sysdate,add_months(sysdate,1) from dual; --加1⽉select sysdate,to_char(sysdate+7,'yyyy-mm-dd HH24:MI:SS') from dual; --加1星期select sysdate,to_char(sysdate+1,'yyyy-mm-dd HH24:MI:SS') from dual; --加1天select sysdate,to_char(sysdate+1/24,'yyyy-mm-dd HH24:MI:SS') from dual; --加1⼩时select sysdate,to_char(sysdate+1/24/60,'yyyy-mm-dd HH24:MI:SS') from dual; --加1分钟select sysdate,to_char(sysdate+1/24/60/60,'yyyy-mm-dd HH24:MI:SS') from dual; --加1秒减法select sysdate,add_months(sysdate,-12) from dual; --减1年select sysdate,add_months(sysdate,-1) from dual; --减1⽉select sysdate,to_char(sysdate-7,'yyyy-mm-dd HH24:MI:SS') from dual; --减1星期select sysdate,to_char(sysdate-1,'yyyy-mm-dd HH24:MI:SS') from dual; --减1天select sysdate,to_char(sysdate-1/24,'yyyy-mm-dd HH24:MI:SS') from dual; --减1⼩时select sysdate,to_char(sysdate-1/24/60,'yyyy-mm-dd HH24:MI:SS') from dual; --减1分钟select sysdate,to_char(sysdate-1/24/60/60,'yyyy-mm-dd HH24:MI:SS') from dual; --减1秒⼀、常⽤⽇期数据格式1.Y或YY或YYY 年的最后⼀位,两位或三位Select to_char(sysdate,'Y') from dual;Select to_char(sysdate,'YY') from dual;Select to_char(sysdate,'YYY') from dual;2.Q 季度 1~3⽉为第⼀季度,2表⽰第⼆季度。
Oracle日期函数大全
ORACLE日期时间函数大全TO_DATE格式(以时间:2007-11-02 13:45:25为例)Year:yy two digits 两位年显示值:07yyy three digits 三位年显示值:007yyyy four digits 四位年显示值:2007Month:mm number 两位月显示值:11mon abbreviated 字符集表示显示值:11月,若是英文版,显示novmonth spelled out 字符集表示显示值:11月,若是英文版,显示novemberDay:dd number 当月第几天显示值:02ddd number 当年第几天显示值:02dy abbreviated 当周第几天简写显示值:星期五,若是英文版,显示friday spelled out 当周第几天全写显示值:星期五,若是英文版,显示fridayddspth spelled out, ordinal twelfthHour:hh two digits 12小时进制显示值:01hh24 two digits 24小时进制显示值:13Minute:mi two digits 60进制显示值:45Second:ss two digits 60进制显示值:25其它Q digit 季度显示值:4WW digit 当年第几周显示值:44W digit 当月第几周显示值:124小时格式下时间范围为:0:00:00 - 23:59:59....12小时格式下时间范围为:1:00:00 - 12:59:59 ....1. 日期和字符转换函数用法(to_date,to_char)select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') as nowTime from dual; //日期转化为字符串select to_char(sysdate,'yyyy') as nowYear from dual; //获取时间的年select to_char(sysdate,'mm') as nowMonth from dual; //获取时间的月select to_char(sysdate,'dd') as nowDay from dual; //获取时间的日select to_char(sysdate,'hh24') as nowHour from dual; //获取时间的时select to_char(sysdate,'mi') as nowMinute from dual; //获取时间的分select to_char(sysdate,'ss') as nowSecond from dual; //获取时间的秒select to_date('2004-05-07 13:23:44','yyyy-mm-dd hh24:mi:ss') from dual//2.select to_char( to_date(222,'J'),'Jsp') from dual显示Two Hundred Twenty-Two3.求某天是星期几select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day') from dual;星期一select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE = American') from dual;monday设置日期语言ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN';也可以这样TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American')4. 两个日期间的天数ceil(n) 取大于等于数值n的最小整数floor(n)取小于等于数值n的最大整数SELECT floor(TO_DATE('2008-05-02 00:00:00', 'yyyy-mm-dd hh24-mi-ss') -TO_DATE('2008-04-30 23:59:59', 'yyyy-mm-dd hh24-mi-ss')) 相差天数FROM DUAL;相差天数1SELECT ceil(TO_DATE('2008-05-02 00:00:00', 'yyyy-mm-dd hh24-mi-ss') -TO_DATE('2008-04-30 23:59:59', 'yyyy-mm-dd hh24-mi-ss')) 相差天数FROM DUAL;相差天数---------25. 时间为null的用法select id, active_date from table1UNIONselect 1, TO_DATE(null) from dual;注意要用TO_DATE(null)6.月份差a_date between to_date('20011201','yyyymmdd') and to_date('20011231','yyyymmdd')那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。
Oracle日期函数大全(各函数锦集)
Oracle日期函数大全(各函数锦集)一、常用日期数据格式1.Y或YY或YYY 年的最后一位,两位或三位SQL> Select to_char(sysdate,'Y') from dual; TO_CHAR(SYSDATE,'Y')--------------------7SQL> Select to_char(sysdate,'YY') from dual; TO_CHAR(SYSDATE,'YY')---------------------07SQL> Select to_char(sysdate,'YYY') from dual; TO_CHAR(SYSDATE,'YYY')----------------------0072.Q 季度1~3月为第一季度,2表示第二季度。
SQL> Select to_char(sysdate,'Q') from dual; TO_CHAR(SYSDATE,'Q')--------------------23.MM 月份数SQL> Select to_char(sysdate,'MM') from dual; TO_CHAR(SYSDATE,'MM')---------------------054.RM 月份的罗马表示(V在罗马数字中表示5)SQL> Select to_char(sysdate,'RM') from dual; TO_CHAR(SYSDATE,'RM')---------------------5.Month 用9个字符长度表示的月份名SQL> Select to_char(sysdate,'Month') from dual;TO_CHAR(SYSDATE,'MONTH')------------------------5月6.WW 当年第几周(2007年5月29日为2007年第22周)SQL> Select to_char(sysdate,'WW') from dual;TO_CHAR(SYSDATE,'WW')---------------------227.W 本月第几周(2007年5月29日为5月第5周)SQL> Select to_char(sysdate,'W') from dual;TO_CHAR(SYSDATE,'W')--------------------58.DDD 当年第几天(2007年5月29日为2007年第149天)SQL> Select to_char(sysdate,'DDD') from dual;TO_CHAR(SYSDATE,'DDD')----------------------1499. DD 当月第几天SQL> Select to_char(sysdate,'DD') from dual;TO_CHAR(SYSDATE,'DD')---------------------2910.D 周内第几天SQL> Select to_char(sysdate,'D') from dual;TO_CHAR(SYSDATE,'D')--------------------11.DY 中文的星期几((2007年5月29日为星期二))SQL> Select to_char(sysdate,'DY') from dual;TO_CHAR(SYSDATE,'DY')---------------------星期二12.HH或HH12 12进制小时数(16:09分为用12小时制计时为4点)SQL> Select to_char(sysdate,'HH') from dual;TO_CHAR(SYSDATE,'HH')---------------------0413.HH24 24小时制SQL> Select to_char(sysdate,'HH24') from dual;TO_CHAR(SYSDATE,'HH24')-----------------------16二、常用时间函数1.trunc(sysdate,'Q') 本季度第一天SQL> select trunc(sysdate,'Q') from dual;TRUNC(SYSDATE,'Q')------------------2007-4-12.trunc(sysdate,'D') 本周的第一天(周日)SQL> select trunc(sysdate,'D')from dual;TRUNC(SYSDATE,'D')------------------2007-5-27/doc/d112362228.html,st_day(sysdate) 本月最后一天SQL> select last_day(sysdate) from dual;LAST_DAY(SYSDATE)-----------------2007-5-31 15:20:34.add_months(sysdate,2) 日期sysdate后推2个月SQL> select add_months(sysdate,2) from dual;ADD_MONTHS(SYSDATE,2)---------------------2007-7-29 15:21:145.next_day(sysdate,2) 日期sysdate之后的第一周中,第2(指定星期的第几天)是什么日期SQL> select next_day(sysdate,2) from dual;NEXT_DAY(SYSDATE,2)-------------------2007-6-4 15:22:106.Months_between(f,s) 日期f和s间相差月数SQL> selectmonths_between(sysdate,to_date('2007-04-12','yyyy-mm-dd'))from dual; MONTHS_BETWEEN(SYSDATE,TO_DATE ------------------------------1.569099089008367.得到SYSDATE+5所在的月份SQL> SELECT to_char(SYSDATE+5,'mon','nls_date_language=american') FROM dual;TO_CHAR(SYSDATE+5,'MON','NLS_D------------------------------jun8.current_date()返回当前会话时区中的当前日期。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
四、年份加减:
Oracle并不直接提供对年份进行加减的函数,不过有了add_months和months_between函数,我们照样可以做到。
【1】为当前日期加上2年: SQL> select add_months(sysdate, 2*12) two_years_later
2 from dual;
ERROR at line 1:
ORA-01846: 周中的日无效
很奇怪!是不?明明语法没有问题,但为什么会说“周中的日无效”呢?这里就不得不说到Oracle中的语言和时区的问题了。下面这张图是使用TOAD截取出来的客户端session的语言和时区信息:
图一
从图中我们知道了客户端的语言是简体中文,日期使用的语言也是简体中文,这就是为什么上面的SQL语句出错的原因了,因为在中文中只有“星期一,星期二”这样的工作日表示,而没有“Monday,Firday”这样的写法!
TRUNC
Truncates a date/time value to a specific element
二、日期加减:
在Oralce中,对日期进行加减操作的默认单位是天,也就是说如果我们向当前日期加1的话是加上一天,而不是一秒或一小时。那么对一天中的一段时间进行加减要怎么做呢?很简单!只需将它们转化为以天为单位即可。
2 to_date('2008-01-01 01:00:00', 'yyyy-mm-dd hh:mi:ss')) result
3 from dual;
RESULT
----------
8203
months_between函数有2个参数,第一个参数是结束日期,第二个参数是开始日期,Oracle用第一个参数减去第二个参数得到月份数。所以结果有可能会是负数的。
SQL>
我们看到了在绿色高亮处使用30/24/60将分钟转换成天。另外一个要注意的地方是:SQL*PLUS环境下默认的日期格式:NLS_DATE_FORMAT是DD-MM-YYYY,也即是不包含时、分、秒,所以我们这里必须采用to_char的方式指定输入的日期格式。
除此之外也可以通过在SQL*PLUS中执行下列语句修改默认的日期输出格式,这样的话就不需要通过to_char来转换了,直接输出就行。 alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss';
ADD_MONTHS
----------
31-12月-07
【3】求两个日期相差的月数:
通常情况下两个时间相减将得到以天数为单位的结果,可是有时我们更希望得到以月为单位的结果,如果手动转换这太麻烦了,所以Oracle又提供了一个函数,这个函数就是months_between。 SQL> select months_between(sysdate,
3 from dual;
NOW_DATE NEW_DATE
-------------------------------------- --------------------------------------
2008-06-30 10:47:31 2008-06-30 11:17:31
下面我们看看如何得到下个星期五的日期:
SQL> select next_day(sysdate, 'Friday') "Next Friday" from dual;
select next_day(sysdate, 'Friday') "Next Friday" from dual
*
SQL> select last_day(sysdate) last_day
2 from dual;
LAST_DAY
----------
31-8月 -08
六、求每月的第一天:
Oracle提供了last_day让我们能够求出所在月份的最后一天,但没有对应的first_day函数,如果有这方面的需求,只需要稍微动一下脑筋,利用last_day函数即可。例如下面的SQL语句就是求出下个月的第一天: SQL> select last_day(sysdate)+1 fisrt_day
【1】为当前时间加上6个月: SQL> select add_months(sysdate, 6) from dual;
ADD_MONTHS
----------
31-12月-08
【2】为当前时间减去6个月: SQL> select add_months(sysdate, -6) from dual;
一、Oracle的日期函数:
Oracle从8i开始就提供了大量的日期函数,这些日期函数包括对日期进行加减、转换、截取等功能。下面是Oracle提供的日期函数一览表 Function
Use
ADD_MONTHS
Adds months to a date
LAST_DAY
Computes the last day of the month
只需要加上一个负数即可以了。
三、月份加减:
月份的加减和日期加减相比要难了很多,因为每个月份的天数并不是固定的,可能是31,30,29,28。如果采用上面的方法将月份转换成实际天数将不可避免地出现多个判断,幸亏Oracle为我们提供了一个add_months函数,这个函数会自动判断月份的天数。看看下面的例子:
【1】为当前时间加上30分钟: SQL> select to_char(sysdate, 'yyyy-mm-dd hh:mi:ss') now_date,
2 to_char(sysdate+(30/24/60), 'yyyy-mm-dd hh:mi:ss') new_date
【2】为当前时间减去30分钟: SQL> select to_char(sysdate+(-30/24/60),'yyyy-mm-dd hh:mi:ss') new_date from dual;
NEW_DATE
--------------------------------------
2008-06-30 10:24:59
TWO_YEARS_
----------
30-6月 -10
【2】求两个日期相差几年: SQL> select months_between(sysdate,
2 to_date('2006-06-30', 'yyyy-mm-dd')) / 12 years_between
ROUND
Rounds a date/time value to a specified element
SYSDATE
Returns the current date and time
TO_CHAR
Converts dates to strings
TO_DATE
Converts strings and numbers to dates
from dual;
求当前月的第一天:
select last_day(add_months(sysdate,-1))+1 from dual
在这里我们将“每月的第一天”转换成“上个月最后一天的下一天”,问题就解决了!
七、求下一个星期几:
有时候我们会碰上“下个星期五是几号啊?”这样常见的问题。Oracle为此提供了一个函数:next_day,它的语法是这样的:next_day(date, string)。其中第一个参数date告诉Oracle从什么时候开始算起,第二个参数string则告诉Oracle要取的工作日。
SQL> select next_day(sysdate,'星期五') "下周五" from dual;
下周五
----------
04-7月 -08
如果你不确定自己的时区或者你担心从一个时区移植到另一个时区时,SQL语句会出错,Oracle还允许你用数字的形式来表示工作日。但是要记得一点:1表示的是周日,2表示的是周一,3表示的是周二,依此类推。
3 from dual;
YEARS_BETWEEN
-------------
2
直接将两个日期相减,然后除以365天并不准确,但是不管一年有多少天它总是只有12个月,所以利用这一点我们可以先求出两个日期相差的月数,再除以12就得出相差的年数了
五、求每月的最后一天:
例如我要查下个周三是什么时候,则函数是这样写的:next_day(sysdate, 4)。 SQL> select next_day(sysdate,4) from dual;
NEXT_DAY(S
----------
02-7月 -08
MONTHS_BETWEEN
Determines the number of months between two dates
NEW_TIME
Translates a time to a new time zone
NEXT_DAY
Returns the date of the next specified weekday