Oracle中的INTERVAL数据类型详解

NTERVAL YEAR TO MONTH数据类型 Oracle语法: INTERVAL integer [- integer] {YEAR | MONTH} [(precision)][TO {YEAR | MONTH}] 该数据类型常用来表示一段时间差, 注意时间差只精确到年和月. precision为年或月的精确域, 有效范围是0到9, 默认值为2. eg: INTER

NTERVAL YEAR TO MONTH数据类型

Oracle语法:
INTERVAL ‘integer [- integer]’ {YEAR | MONTH} [(precision)][TO {YEAR | MONTH}]

该数据类型常用来表示一段时间差, 注意时间差只精确到年和月. precision为年或月的精确域, 有效范围是0到9, 默认值为2.

eg:
INTERVAL ‘123-2’ YEAR(3) TO MONTH    
表示: 123年2个月, “YEAR(3)” 表示年的精度为3, 可见”123″刚好为3为有效数值, 如果该处YEAR(n), n
INTERVAL ‘123’ YEAR(3)
表示: 123年0个月

INTERVAL ‘300’ MONTH(3)
表示: 300个月, 注意该处MONTH的精度是3啊.

INTERVAL ‘4’ YEAR    
表示: 4年, 同 INTERVAL ‘4-0’ YEAR TO MONTH 是一样的

INTERVAL ’50’ MONTH    
表示: 50个月, 同 INTERVAL ‘4-2’ YEAR TO MONTH 是一样

INTERVAL ‘123’ YEAR    
表示: 该处表示有错误, 123精度是3了, 但系统默认是2, 所以该处应该写成 INTERVAL ‘123’ YEAR(3) 或”3″改成大于3小于等于9的数值都可以的

INTERVAL ‘5-3′ YEAR TO MONTH + INTERVAL ’20’ MONTH =
INTERVAL ‘6-11’ YEAR TO MONTH
表示: 5年3个月 + 20个月 = 6年11个月

与该类型相关的函数:
NUMTODSINTERVAL(n, ‘interval_unit’)
将n转换成interval_unit所指定的值, interval_unit可以为: DAY, HOUR, MINUTE, SECOND
注意该函数不可以转换成YEAR和MONTH的.

NUMTOYMINTERVAL(n, ‘interval_unit’)
interval_unit可以为: YEAR, MONTH

eg: (Oracle Version 9204, RedHat Linux 9.0)
SQL> select numtodsinterval(100,’DAY’) from dual;

NUMTODSINTERVAL(100,’DAY’)                                                     
—————————————————————————    
+000000100 00:00:00.000000000                                                 

SQL> c/DAY/SECOND
  1* select numtodsinterval(100,’SECOND’) from dual
SQL> /

NUMTODSINTERVAL(100,’SECOND’)                                                  
—————————————————————————    
+000000000 00:01:40.000000000                                                 

SQL> c/SECOND/MINUTE
  1* select numtodsinterval(100,’MINUTE’) from dual
SQL> /

NUMTODSINTERVAL(100,’MINUTE’)                                                  
—————————————————————————    
+000000000 01:40:00.000000000                                                 

SQL> c/MINUTE/HOUR
  1* select numtodsinterval(100,’HOUR’) from dual
SQL> /

NUMTODSINTERVAL(100,’HOUR’)                                                    
—————————————————————————    
+000000004 04:00:00.000000000                                                 

SQL> c/HOUR/YEAR
  1* select numtodsinterval(100,’YEAR’) from dual
SQL> /
select numtodsinterval(100,’YEAR’) from dual
                           *
ERROR at line 1:
ORA-01760: illegal argument for function

SQL> select numtoyminterval(100,’year’) from dual;

NUMTOYMINTERVAL(100,’YEAR’)                                                    
—————————————————————————    
+000000100-00                                                                 

SQL> c/year/month
  1* select numtoyminterval(100,’month’) from dual
SQL> /

NUMTOYMINTERVAL(100,’MONTH’)                                                   
—————————————————————————    
+000000008-04                                                                 

时间的计算:
SQL> select to_date(‘1999-12-12′,’yyyy-mm-dd’) – to_date(‘1999-12-01′,’yyyy-mm-dd’) from dual;

TO_DATE(‘1999-12-12′,’YYYY-MM-DD’)-TO_DATE(‘1999-12-01′,’YYYY-MM-DD’)          
———————————————————————          
                                                                   11          
— 可以相减的结果为天.

SQL> c/1999-12-12/1999-01-12
  1* select to_date(‘1999-01-12′,’yyyy-mm-dd’) – to_date(‘1999-12-01′,’yyyy-mm-dd’) from dual
SQL> /

TO_DATE(‘1999-01-12′,’YYYY-MM-DD’)-TO_DATE(‘1999-12-01′,’YYYY-MM-DD’)          
———————————————————————          
                                                                 -323          
— 也可以为负数的

SQL> c/1999-01-12/2999-10-12
  1* select to_date(‘2999-10-12′,’yyyy-mm-dd’) – to_date(‘1999-12-01′,’yyyy-mm-dd’) from dual
SQL> /

TO_DATE(‘2999-10-12′,’YYYY-MM-DD’)-TO_DATE(‘1999-12-01′,’YYYY-MM-DD’)          
———————————————————————          
                                                               365193         

下面看看INTERVAL YEAR TO MONTH怎么用.
SQL> create table bb(a date, b date, c interval year(9) to month);

Table created.

SQL> desc bb;
Name                                      Null?    Type
—————————————– ——– —————————-
A                                                  DATE
B                                                  DATE
C                                                  INTERVAL YEAR(9) TO MONTH

SQL> insert into bb values(to_date(‘1985-12-12’, ‘yyyy-mm-dd’), to_date(‘1984-12-01′,’yyyy-mm-dd’), null)

1 row created.

SQL> select * from bb;

A         B                                                                    
——— ———                                                            
C                                                                              
—————————————————————————    
12-DEC-85 01-DEC-84                                                            
                                                                               
                                                                               
SQL> update bb set c = numtoyminterval(a-b, ‘year’);

1 row updated.

SQL> select * from bb;

A         B                                                                    
——— ———                                                            
C                                                                              
—————————————————————————    
12-DEC-85 01-DEC-84                                                            
+000000376-00                                                                  
                                                                               
— 直接将相减的天变成年了, 因为我指定变成年的
SQL> select a-b, c from bb;

       A-B                                                                     
———-                                                                     
C                                                                              
—————————————————————————    
       376                                                                     
+000000376-00                                                                  
                                                                              

SQL> insert into bb values(null,null,numtoyminterval(376,’month’));

1 row created.

SQL> select * from bb;

A         B             C                                                       
——— ———    ——————————————–    
12-DEC-85 01-DEC-84    +000000376-00                                                                  
                         +000000031-04                                        

SQL> insert into bb values ( null,null, numtoyminterval(999999999,’year’));

1 row created.

SQL> select * from bb;

A           B            C                                
———   ———     ———————————————————————    
12-DEC-85   01-DEC-84   +000000376-00                                                                  
                          +000000031-04
                          +999999999-00                                                               

========================

INTERVAL YEAR TO MONTH类型2个TIMESTAMP类型的时间差别。内部类型是182,长度是5。其中4个字节存储年份差异,存储的时候在差异上加了一个0X80000000的偏移量。一个字节存储月份的差异,这个差异加了60的偏移量。

SQL> ALTER TABLE TestTimeStamp ADD E INTERVAL YEAR TO MONTH;
SQL> update testTimeStamp set e=(select interval ‘5’ year + interval ’10’ month year  from dual);

已更新3行。

SQL> commit;
提交完成。

SQL> select dump(e,16) from testTimeStamp;

DUMP(E,16)
———————————————
Typ=182 Len=5: 80,0,0,5,46
Typ=182 Len=5: 80,0,0,5,46
Typ=182 Len=5: 80,0,0,5,46

年:0X80000005-0X80000000=5
月:0x46-60=10

INTERVAL DAY TO SECOND数据类型

Oracle语法:
INTERVAL ‘{ integer | integer time_expr | time_expr }’
{ { DAY | HOUR | MINUTE } [ ( leading_precision ) ]
| SECOND [ ( leading_precision [, fractional_seconds_precision ] ) ] }
[ TO { DAY | HOUR | MINUTE | SECOND [ (fractional_seconds_precision) ] } ]

leading_precision值的范围是0到9, 默认是2. time_expr的格式为:HH[:MI[:SS[.n]]] or MI[:SS[.n]] or SS[.n], n表示微秒.
该类型与INTERVAL YEAR TO MONTH有很多相似的地方,建议先看INTERVAL YEAR TO MONTH再看该文.

范围值:
HOUR:    0 to 23
MINUTE: 0 to 59
SECOND: 0 to 59.999999999

eg:
INTERVAL ‘4 5:12:10.222’ DAY TO SECOND(3)
表示: 4天5小时12分10.222秒

INTERVAL ‘4 5:12’ DAY TO MINUTE
表示: 4天5小时12分

INTERVAL ‘400 5’ DAY(3) TO HOUR
表示: 400天5小时, 400为3为精度,所以”DAY(3)”, 注意默认值为2.

INTERVAL ‘400’ DAY(3)
表示: 400天

INTERVAL ’11:12:10.2222222′ HOUR TO SECOND(7)
表示: 11小时12分10.2222222秒

INTERVAL ’11:20′ HOUR TO MINUTE
表示: 11小时20分

INTERVAL ’10’ HOUR
表示: 10小时

INTERVAL ’10:22′ MINUTE TO SECOND
表示: 10分22秒

INTERVAL ’10’ MINUTE
表示: 10分

INTERVAL ‘4’ DAY
表示: 4天

INTERVAL ’25’ HOUR
表示: 25小时

INTERVAL ’40’ MINUTE
表示: 40分

INTERVAL ‘120’ HOUR(3)
表示: 120小时

INTERVAL ‘30.12345’ SECOND(2,4)    
表示: 30.1235秒, 因为该地方秒的后面精度设置为4, 要进行四舍五入.

INTERVAL ’20’ DAY – INTERVAL ‘240’ HOUR = INTERVAL ’10-0′ DAY TO SECOND
表示: 20天 – 240小时 = 10天0秒

==================
该部分来源:http://www.Oraclefans.cn/forum/showblog.jsp?rootid=140
INTERVAL DAY TO SECOND类型存储两个TIMESTAMP之间的时间差异,用日期、小时、分钟、秒钟形式表示。该数据类型的内部代码是183,长度位11字节:

l         4个字节表示天数(增加0X80000000偏移量)
l         小时、分钟、秒钟各用一个字节表示(增加60偏移量)
l         4个字节表示秒钟的小时差异(增加0X80000000偏移量)

以下是一个例子:

SQL> alter table testTimeStamp add f interval day to second ;

表已更改。

SQL> update testTimeStamp set f=(select interval ‘5’ day + interval ’10’ second from dual);

已更新3行。

SQL> commit;

提交完成。

SQL> select dump(f,16) from testTimeStamp;

DUMP(F,16)

——————————————————————————–

Typ=183 Len=11: 80,0,0,5,3c,3c,46,80,0,0,0
Typ=183 Len=11: 80,0,0,5,3c,3c,46,80,0,0,0
Typ=183 Len=11: 80,0,0,5,3c,3c,46,80,0,0,0

日期:0X80000005-0X80000000=5

小时:60-60=0
分钟:60-60=0
秒钟:70-60=10
秒钟小数部分:0X80000000-0X80000000=0

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1082850.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 19:59:58
下一篇 2025年12月2日 20:01:44

相关推荐

  • Java中MANIFEST.MF的作用 详解清单文件

    manifest.mf是java中jar文件的元数据配置文件,位于meta-inf目录下,用于定义版本、主类、依赖路径等关键信息。1. 它允许指定入口类,使jar可直接运行;2. 通过class-path管理依赖,减少类加载冲突;3. 可配置安全权限,如设置沙箱运行;4. 常见属性包括manifes…

    2025年12月5日 java
    000
  • Java中枚举类型怎么定义 掌握Java枚举的定义和常用方法

    java中定义枚举类型使用enum关键字,例如public enum weekday { monday, tuesday,…};枚举可包含字段和方法,如添加中文名称字段及获取方法;可在switch语句中使用,确保覆盖所有值;常用方法包括values()、valueof()、ordinal…

    2025年12月4日 java
    000
  • oracle/mysql拼接值遇到的坑及双竖线||和concat怎么使用

    %ign%ignore_a_1%re_a_1% mysql 拼接值遇到的坑 双竖线 || concat || “||” 在oracle中是拼接值,但在mysql中是“或”的意思。 where name like ‘%’ || ‘Tony’ || ‘%’ 所以推荐使用concat() concat()…

    数据库 2025年12月4日
    000
  • Linux实现自动挂载autofs的方法详解

    ☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜ 目录 实现自动挂载-autofs autofs工具简单使用 autofs配置详细说明 自动挂载资源有两种格式 优化Linux系统性能 安装Tuned 选择调整配置文件 检查系统推荐的调整配置文件…

    2025年12月4日
    000
  • 简易项目搭建(用于一般杂七杂八的小功能点)

    在工作中,我们常常会遇到许多需要完成的小功能点。以我自己的工作情况为例,最常见的是两个方面:1、控制台项目;2、web界面(纯前端)。 首先让我们讨论控制台项目的工作内容。在没有使用PostMan之前,工作中大量使用接口调用。在项目准备阶段,首先需要对接口的使用进行描述。在主要使用WebServic…

    2025年12月4日
    000
  • 分页功能如何实现?LIMIT与页码计算

    分页功能通过offset和limit截取数据实现。1.分页核心是计算偏移量(offset=(页码-1)每页条数)和限制数量;2.使用sql的limit子句或数据库特定语法(如sql server的offset…fetch next)执行查询;3.前端传页码和每页大小,后端计算偏移量并执行…

    2025年12月3日 后端开发
    000
  • Java中DAO模式的作用 解析DAO模式封装数据访问的价值

    dao模式通过解耦业务逻辑与数据访问,解决了数据库切换困难、sql注入风险和代码重复问题。其核心价值在于将数据访问细节封装在接口和实现类中,使业务代码仅面向接口编程,从而降低维护成本。具体步骤包括:1.定义dao接口;2.创建具体实现类;3.使用工厂模式获取实例;4.在业务逻辑中调用dao方法。技术…

    2025年12月3日 java
    000
  • Swoole如何做数据加密?加密算法如何选择?

    Swoole中数据加密依赖PHP的OpenSSL扩展,通过选择AES、RSA等算法实现;在Server或Client的接收与发送过程中进行加解密操作,结合CBC、GCM等模式保障安全与性能;密钥应通过环境变量或配置文件管理,避免硬编码;为防止中间人攻击,应启用TLS/SSL加密通信,并在WebSoc…

    2025年12月3日
    100
  • Swoole如何实现多租户?租户隔离怎么操作?

    Swoole实现多租户的核心在于协程上下文隔离,通过Coroutine::getContext()绑定租户ID、数据库连接、缓存前缀等上下文信息,在请求入口识别租户并加载配置,确保数据、缓存、文件存储、数据库连接等资源按租户隔离,避免长驻内存导致的数据泄露,结合连接池重置、缓存键前缀、独立表或库等策…

    2025年12月3日
    000
  • 2023合同管理软件排名:前10名榜单

    合同管理软件依托信息技术,结合现代企业的先进管理思想,为企业构建起一个集决策、规划、控制及经营绩效评估于一体的全方位、系统化的管理平台。企业在开展经济活动时,通常以合同为纽带,合同管理的效果直接关系到经营的成败。作为企业管理的重要组成部分,合同管理对业务流程的规范化、数据的准确性以及信息传递的安全性…

    2025年12月3日 软件教程
    000
  • 如何在PHP中配置Oracle数据库连接池的详细教程?

    在php中配置oracle数据库连接池需依赖oracle工具和配置,而非php本身。1. 安装oracle instant client并配置环境变量,安装oci8扩展并在php.ini中启用;2. 在oracle端启用drcp连接池,使用dbms_connection_pool包启动并调整参数;3…

    2025年12月3日 后端开发
    000
  • 零基础学Java课程安排建议

    it行业目前非常热门,对于大学生而言,若想在大学期间学习java但又毫无基础,以下是一份适合的课程学习流程推荐: 1、 公共基础知识:初步了解计算机网络和数据结构的基础内容,掌握基本概念即可。 2、 Java基础课程大约需要三周时间完成,建议从视频教程开始学习。学完后可以在网上找一套系统的练习题进行…

    2025年12月3日 软件教程
    000
  • Windows2003系统下MySQL安装小结

    本文承接上文在windows2003系统中配置支持php的tomcat网站内容继续进行说明。 1、 支持列表中并未列出Windows 2003版本。 2、 我下载了社区版5.7.22,但在安装过程中提示“mysqld不是有效的Win32应用程序”,令人费解。 3、 随后选择降低版本,改用5.6.40…

    2025年12月3日 软件教程
    000
  • Oracle视图应用实战

    1、 在Oracle数据库中创建视图,并通过查询语句获取视图中的数据内容。 2、 对已存在的Oracle视图进行结构或定义修改,并执行重新编译以确保其有效性。 3、 %ignore_a_1%览当前数据库中存在的视图列表,并根据需要删除指定的视图对象。 4、 执行对Oracle视图的数据查询操作,同时…

    2025年12月3日 软件教程
    000
  • sql中如何实现递归查询 递归查询的经典案例演示

    sql递归查询通过cte实现层级数据查询,核心在于锚点成员与递归成员结合,常见错误包括无限循环、性能问题、数据类型不匹配等;优化方法有索引优化、限制递归深度、使用临时表等;不同数据库如postgresql、sql server、mysql支持递归cte,oracle则使用connect by语法。 …

    2025年12月3日 数据库
    000
  • SQL变量声明怎么写 变量声明的2种语法解析

    sql变量声明主要有两种方式:使用declare关键字和mysql的@符号。1. declare用于多数数据库,如sql server和oracle,需指定数据类型及可选初始值;2. mysql用set @variablename = value形式声明会话变量,无需预定义类型。常见数据类型包括数值…

    2025年12月3日 数据库
    000
  • SQL中UPPER和LOWER函数的大小写转换 字母大小写转换的便捷方法

    upper和lower函数用于统一数据大小写格式并实现不区分大小写的查询。upper将字符串转为大写,如upper(‘hello world’)返回’hello world’;lower将字符串转为小写,如lower(‘hello worl…

    2025年12月3日 数据库
    000
  • 如何使用SQL工具进行数据库的自动化测试和验证

    sql工具在数据库自动化测试和验证中的应用非常广泛,可以有效提高工作效率和确保数据的正确性与一致性。1) 使用sql server management studio (ssms)等工具进行库存管理系统的自动化测试,确保高并发情况下库存更新和订单处理的准确性。2) 通过事务和锁机制处理并发测试,确保…

    2025年12月3日 数据库
    000
  • sql和mysql有啥区别 sql和mysql的区别是什么

    sql和mysql是不同的:sql是管理和操作关系数据库的标准语言,而mysql是遵循sql标准的具体数据库管理系统。sql的标准化使其在不同数据库环境中通用,mysql则在sql基础上添加独特功能和优化,如存储引擎和扩展语法。 在编程界,SQL和MySQL就像是孪生兄弟,但又各有千秋。让我们深入探…

    2025年12月3日 数据库
    000
  • SQL语句中如何排除某些值 用SQL排除特定值的完整方案

    SQL中排除某些值,其实就是筛选出“不是这些值”的数据。核心在于使用NOT IN、!= 或者 NOT EXISTS等操作符,具体用哪个取决于你的场景和数据结构。 解决方案 排除特定值的方法有很多,这里列举几种常见的: 使用 NOT IN: 这是最直观的方式,直接指定要排除的值列表。 SELECT *…

    2025年12月3日 数据库
    000

发表回复

登录后才能评论
关注微信