




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
一、Oracle的日期函数:Oracle从8i开始就提供了大量的日期函数,这些日期函数包括对日期进行加减、转换、截取等功能。下面是Oracle提供的日期函数一览表 Function UseADD_MONTHS Adds months to a dateLAST_DAY Computes the last day of the monthMONTHS_BETWEEN Determines the number of months between two datesNEW_TIME Translates a time to a new time zoneNEXT_DAY Returns the date of the next specified weekday ROUND Rounds a date/time value to a specified elementSYSDATE Returns the current date and timeTO_CHAR Converts dates to strings TO_DATE Converts strings and numbers to datesTRUNC Truncates a date/time value to a specific element二、日期加减:在Oralce中,对日期进行加减操作的默认单位是天,也就是说如果我们向当前日期加1的话是加上一天,而不是一秒或一小时。那么对一天中的一段时间进行加减要怎么做呢?很简单!只需将它们转化为以天为单位即可。【1】为当前时间加上30分钟: SQL select to_char(sysdate, yyyy-mm-dd hh:mi:ss) now_date, to_char(sysdate+(30/24/60), yyyy-mm-dd hh:mi:ss) new_date from dual;NOW_DATE NEW_DATE- -2008-06-30 10:47:31 2008-06-30 11:17:31SQL 我们看到了在绿色高亮处使用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;【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只需要加上一个负数即可以了。三、月份加减:月份的加减和日期加减相比要难了很多,因为每个月份的天数并不是固定的,可能是31,30,29,28。如果采用上面的方法将月份转换成实际天数将不可避免地出现多个判断,幸亏Oracle为我们提供了一个add_months函数,这个函数会自动判断月份的天数。看看下面的例子:【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;ADD_MONTHS-31-12月-07【3】求两个日期相差的月数:通常情况下两个时间相减将得到以天数为单位的结果,可是有时我们更希望得到以月为单位的结果,如果手动转换这太麻烦了,所以Oracle又提供了一个函数,这个函数就是months_between。 SQL select months_between(sysdate, to_date(2008-01-01 01:00:00, yyyy-mm-dd hh:mi:ss) result from dual; RESULT-5.94928203months_between函数有2个参数,第一个参数是结束日期,第二个参数是开始日期,Oracle用第一个参数减去第二个参数得到月份数。所以结果有可能会是负数的。四、年份加减:Oracle并不直接提供对年份进行加减的函数,不过有了add_months和months_between函数,我们照样可以做到。【1】为当前日期加上2年: SQL select add_months(sysdate, 2*12) two_years_later from dual;TWO_YEARS_-30-6月 -10【2】求两个日期相差几年: SQL select months_between(sysdate, to_date(2006-06-30, yyyy-mm-dd) / 12 years_between from dual;YEARS_BETWEEN-直接将两个日期相减,然后除以365天并不准确,但是不管一年有多少天它总是只有12个月,所以利用这一点我们可以先求出两个日期相差的月数,再除以12就得出相差的年数了五、求每月的最后一天:SQL select last_day(sysdate) last_day from dual;LAST_DAY-31-8月 -08六、求每月的第一天:Oracle提供了last_day让我们能够求出所在月份的最后一天,但没有对应的first_day函数,如果有这方面的需求,只需要稍微动一下脑筋,利用last_day函数即可。例如下面的SQL语句就是求出下个月的第一天: SQL select last_day(sysdate)+1 fisrt_day 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, Friday) Next Friday from dual;ERROR at line 1:ORA-01846: 周中的日无效很奇怪!是不?明明语法没有问题,但为什么会说“周中的日无效”呢?这里就不得不说到Oracle中的语言和时区的问题了。下面这张图是使用TOAD截取出来的客户端session的语言和时区信息:图一从图中我们知道了客户端的语言是简体中文,日期使用的语言也是简体中文,这就是为什么上面的SQL语句出错的原因了,因为在中文中只有“星期一,星期二”这样的工作日表示,而没有“Monday,Firday”这样的写法!SQL select next_day(sysdate,星期五) 下周五 from dual;下周五-04-7月 -08如果你不确定自己的时区或者你担心从一个时区移植到另一个时区时,S
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 重大自然灾害中档案应急管理机制研究
- 主动脉夹层诊断与护理
- 零售行业代收货款服务条款协议
- 文化创意产业财产抵押贷款协议
- 菜园种植与城市垃圾分类回收合同
- 茶楼茶艺与茶文化主题酒店合作合同范本
- 车库租赁与停车场综合管理合同
- 拆迁安置补偿居间服务协议书
- 电视剧拍摄现场制片助理劳务合作协议
- 彩钢房仓储物流合作项目承包协议
- 基层医院护理课件
- 贵州省贵阳市2022-2023学年七年级下学期语文期末试卷(含答案)
- 法律职业伦理试题及答案
- 2025年国家公务员考录《申论》真题及参考答案(行政执法卷)
- 2024珠海农商银行社会招聘笔试历年典型考题及考点剖析附带答案详解
- 2025年公路水运工程重大事故隐患判定标准
- 综合实践:画数学连环画(大单元教学设计)一年级数学下册北师大版2025
- 车间物料员员试题及答案
- 2025国内外虚拟电厂实践经验分析及高质量发展相关建议报告-国网能源院
- 锚杆锚固质量无损检测技术规程
- 老年痴呆健康知识讲座课件
评论
0/150
提交评论