使用INTERVAL YEAR TO MONTH类型

Oracle Database 9i数据库引入了一种新特性,可以用来存储时间间隔。时间间隔的例子包括:

● 1年零3个月

● 25个月

● -3天5小时16分

● 1天7小时

● -56小时

注意:

不要混淆时间间隔与时间值或时间戳的概念。时间间隔记录的是一段时间长度(例如1年零3个月),而时间值或时间戳记录的是一个特定的日期和时间(例如2006年10月28日下午7点32分16秒)。

在本书假想的在线商店这个例子中,我们可能想在特定的一段时间内对某种商品打折。例如,可以让顾客使用优惠券,其有效期为几个月;或者为在几天内促销产品而打折。本节后面将介绍几个使用优惠券和促销的例子。

表5-10列出了时间间隔的类型。

表5-10  时间间隔类型


类    型


说    明


INTERVAL YEAR[ (years_precision)]TO MONTH


存储一个时间间隔,其单位为年和月;可以通过指定可选的years_precision参数来指定年的精度,该参数是一个0~9的整数。默认的精度为2,意思是可以在时间间隔中为年数存储两位数字。如果试图向表中添加一行年数超过INTERVAL YEAR TO MONTH列可以存储的记录,就会返回一个错误。时间间隔既可以存储正数,也可以存储负数


INTERVAL DAY[(days_precision)]

TO SECOND[( seconds_precision)]


存储一个时间间隔,其单位为天和秒;可以通过指定可选的days_precision参数来指定天的精度,该参数是一个0~9的整数,默认值为2。另外,还可以通过指定可选的seconds_precision参数来指定秒的小数部分的精度,该参数是一个0~9的整数,默认值为6。时间间隔既可以存储正数,也可以存储

表5-11  时间间隔字面量的例子


时间间隔字面量


说明


INTERVAL ‘1‘ YEAR


时间间隔为1年


INTERVAL ‘11‘ MONTH


时间间隔为11个月


INTERVAL ‘14‘ MONTH


时间间隔为14个月(等于1年零2个月)


INTERVAL ‘1-3‘ YEAR TO MONTH


时间间隔为1年零3个月


INTERVAL ‘0-5‘ YEAR TO MONTH


时间间隔为0年5个月


INTERVAL ‘123‘ YEAR(3) TO MONTH


时间间隔为123年,精度为3位数字


INTERVAL ‘-1-5‘ YEAR TO MONTH


时间间隔为负数,值为1年零5个月


INTERVAL ‘1234‘ YEAR(3)


时间间隔无效:1234包含4位数字,因此它包含的数字超过了精度(只允许最多3位数字)所允许的范围

SQL示例:

SQL> select interval ‘11‘ month from dual;
INTERVAL‘11‘MONTH
---------------------------------------
+00-11

SQL> select interval ‘11‘ year from dual;
INTERVAL‘11‘YEAR
---------------------------------------
+11-00

SQL> select interval ‘14‘ month from dual;
INTERVAL‘14‘MONTH
---------------------------------------
+01-02

SQL> select interval ‘1-3‘ year to month from dual;
INTERVAL‘1-3‘YEARTOMONTH
---------------------------------------
+01-03

SQL> select interval ‘0-3‘ year to month from dual;
INTERVAL‘0-3‘YEARTOMONTH
---------------------------------------
+00-03
SQL> select interval ‘101‘ year(3) from dual;
INTERVAL‘101‘YEAR(3)
---------------------------------------
+101-00

SQL> select interval ‘-10-5‘ year to month from dual;
INTERVAL‘-10-5‘YEARTOMONTH
---------------------------------------
-10-05

SQL> select interval ‘1234‘ year(3) from dual;
select interval ‘1234‘ year(3) from dual
ORA-01873: 间隔的前导精度太小

SQL> 

5.8.1  使用INTERVAL YEAR TO MONTH类型

INTERVAL YEAR TO MONTH类型可以用来存储单位为年和月的时间间隔。下面这条语句创建一个名为coupons的表,用来存储优惠券信息。coupons表包含了一个INTERVAL YEAR TO MONTH类型的列duration,该列用来记录优惠券有效的时间间隔。注意,此处指定了duration列的精度为3,这就是说可以为该列的年数部分存储3位数字:

 CREATE TABLE coupons (
        coupon_id INTEGER CONSTRAINT coupons_pk PRIMARY KEY,
        name VARCHAR2(30) NOT NULL,
        duration INTERVAL YEAR(3) TO MONTH
        );

要向数据库提供一个INTERVAL YEAR TO MONTH字面值,可以使用下面的简化语法:

INTERVAL ‘[+|-][y][-m]‘ [YEAR[( years_precision)])] [TO MONTH]

其中

● + 或 - 是一个可选的指示符,用来说明时间间隔是正数还是负数(默认为正数)。

● y 是一个可选参数,表示时间间隔的年数部分。

● m 是一个可选参数,表示时间间隔的月数部分。如果指定了年数和月数,必须在INTERVAL子句中包含TO MONTH。

● year_precision是一个可选参数,用来说明年数的精度(默认为2)。

《FROM:http://www.cnblogs.com/theurgy/articles/1549454.html

时间: 2024-10-14 14:33:47

使用INTERVAL YEAR TO MONTH类型的相关文章

INTERVAL YEAR TO MONTH数据类型

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为有效数值,

Oracle 数据库 INTERVAL DAY TO SECOND类型的使用

INTERVAL DAY TO SECOND类型可以用来存储单位为天和秒的时间间隔.下面这条语句创建一个名为promotions的表,用来存储促销信息.promotions表包含了一个INTERVAL DAY TO SECOND类型的列duration,该列用来记录促销有效的时间间隔:  CREATE TABLE promotions (promotion_id INTEGER CONSTRAINT promotions_pk PRIMARY KEY,name VARCHAR2(30) NOT

oracle函数详解

Oracle 数据库中 SQL 分析的主要优势 Oracle 数据库中分析功能和特性提供以下主要优势: 1. 提高开发人员产能 — 开发人员可以通过更清晰.更简洁的 SQL 代码执行复杂分析.现在可以使用一条 SQL 语句表示复杂任务,编写和维护速度更快.效率更高. 2. 提高查询速度 — 数据库中分析支持的处理优化可大幅提高查询性能.以前需要自联接或复杂过程处理的操作现在可以用原生 SQL 执行. 3. 改善可管理性 — 应用程序共享一个公共的关系环境,而非数据结构不兼容的计算引擎组合,因此可

Oracle/Hive/Impala SQL比较(5)

5 Function 指数据库内置的function,不讨论UDF.另外,操作符都不比较了,区别不大. 5.1 数学函数 功能 Oracle Hive Impala ABS 绝对值,有 有 有 SIN/SINH/ASIN/COS/COSH/ACOS/TAN/TANH/ATAN/ATAN2 三角函数 其中ATAN2接受两个参数(二维平面中的坐标) 没有SINH/COSH/TANH/ATAN2 同hive BITAND 按位与,有 CEIL 天花板值,有 有,还有个别名CEILING 有,同hive

ORACLE函数之日期时间转换函数

 1.          TO_CHAR 语法:TO_CHAR(X [,format]) 说明:将X按format格式转换成字符串.X是一个日期或者数字,format是一个规定了X采用何种格式转换的格式字符串 举例: SQL>SELECT TO_CHAR(sysdate,'YYYY-MM-DD hh24:mi:ss') A FROM DUAL; A ------------------- 2014-06-1815:58:43 2.            TO_DATE 语法:TO_DATE(

Oracle 函数大全

F.1字符函数--返回字符值 (chr,concat,initcap,lower,lpad/rpad,nls_initcap,nls_lower,nls_upper,regexp_replace,regexp_substr,replace,trim/ltrim/rtrim,soundex,substr,translate,upper) 说明:可以sql和plsql中使用 CHR 语法:  chr(x) 功能:给出整数X,返回对应的ASCII码字符.CHR和ASCII是一对反函数. SQL> se

PLSQL_基础系列4_时间间隔INTERVAL

2014-12-08 BaoXinjian 一.摘要 INTERVAL数据类型用来存储两个时间戳之间的时间间隔. 可以指定years and months,或者days,hours,minuts,seconds之间的间隔. ORACLE支持两种INTEVAL类型,它们分别是YEAR TO MONTH和DAY TO SECOND. 每个类型都包含leading field和trailing field.主参数定义要被计算的date或者time,副参数定义最小增长量 二.语法 1. Oracle语法

ORACLE与.NET类型对应关系(转)

ORACLE与.NET类型对应关系 想来这个是最重要的事情了,因为多数情况下,我们使用dbhelper来调用数据库的时候,是因为如下三个地方导致错误: 1.错误的sql语句:末尾多了分号,少了部分关键字 2.sql中的参数与parameter[]不对应. 3.parasmeter[]中的数据类型转为Oracle的数据类型中出错. 通常情况下,我们大设置paramenter[]时,只会给出变量名和对应的值(多数是.NET中的变量)去让ODP自动执行数据类型转换,而ODP一般都可以正确的转换,但是,

为已有表快速创建自动分区和Long类型like 的方法-Oracle 11G

对上一篇文章进行实际的运用.在工作中遇到有一张大表(五千万条数据),在开始的时候忘记了创建自动分区,导致现在使用非常不方便,查询的速度非常的满,所以就准备重新的分区表,最原始方法是先创建新的分区表,然后将数据依次插入到新的表中,但是我们的表的数据比较的大,如果这样做可能导致效率相对较低,经过寻扎发现了上一篇文章,这篇文章有三个方法,第一个就是最原始的方法,我没有进行实验,第二种(交换分区)和第三种的(在线重定义)我都进行了测试,第三种方法,我初以为会比较快速,但是经过测试需要超过2个小时的时间,