如何从INTERVAL类型转换为NUMBER类型

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何从INTERVAL类型转换为NUMBER类型相关的知识,希望对你有一定的参考价值。

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
参考技术A with t as (select interval '5' day + interval '10' second a from dual)
select
a,
(extract(hour from a)*60+extract(minute from a))*60+extract(second from a)b,
substr(a,2,9)||substr(a,12,2)||substr(a,15,2)||substr(a,18)x,
substr(a,2,9)*24*3600+substr(a,12,2)*3600+substr(a,15,2))*60+substr(a,18)y
from t;
+000000005 00:00:10.000000000 10
000000005000010.000000000 432010

强制类型转换

通过手动进行类型转换,Javascript提供了以下转型函数:

转换为数值类型:Number(mix)、parseInt(string,radix)、parseFloat(string)

转换为字符串类型:toString(radix)、String(mix)

转换为布尔类型:Boolean(mix)

 1、Number(mix)函数,可以将任意类型的参数mix转换为数值类型。其规则为:

(1)如果是布尔值,true和false分别被转换为1和0。

(2)如果是数字值,返回本身。

(3)如果是null,返回0.

(4)如果是undefined,返回NaN。

(5)如果是字符串,遵循以下规则:

  • 如果字符串中只包含数字,则将其转换为十进制(忽略前导0)

  • 如果字符串中包含有效的浮点格式,将其转换为浮点数值(忽略前导0)

  • 如果是空字符串,将其转换为0

  • 如果字符串中包含非以上格式,则将其转换为NaN

  • 如果是对象,则调用对象的valueOf()方法,然后依据前面的规则转换返回的值。如果转换的结果是NaN,则调用对象的toString()方法,再次依照前面的规则转换返回的字符串值。

下表列出了对象的valueOf()的返回值:

对象

返回值

Array

数组的元素被转换为字符串,这些字符串由逗号分隔,连接在一起。其操作与 Array.toString 和 Array.join 方法相同。

Boolean

Boolean 值。

Date

存储的时间是从 1970 年 1 月 1 日午夜开始计的毫秒数 UTC。

Function

函数本身。

Number

数字值。

Object

对象本身。这是默认情况。

String

字符串值。


2、parseInt(string, radix)函数,将字符串转换为整数类型的数值。它也有一定的规则:

(1)忽略字符串前面的空格,直至找到第一个非空字符

(2)如果第一个字符不是数字符号或者负号,返回NaN

(3)如果第一个字符是数字,则继续解析直至字符串解析完毕或者遇到一个非数字符号为止

(4)如果上步解析的结果以0开头,则将其当作八进制来解析;如果以x开头,则将其当作十六进制来解析

(5)如果指定radix参数,则以radix为基数进行解析

3、parseFloat(string)函数,将字符串转换为浮点数类型的数值。

它的规则与parseInt基本相同,但也有点区别:字符串中第一个小数点符号是有效的,另外parseFloat会忽略所有前导0,如果字符串包含一个可解析为整数的数,则返回整数值而不是浮点数值。

4、toString(radix)方法。除undefined和null之外的所有类型的值都具有toString()方法,其作用是返回对象的字符串表示。

对象

操作

Array

将 Array 的元素转换为字符串。结果字符串由逗号分隔,且连接起来。

Boolean

如果 Boolean 值是 true,则返回 “true”。否则,返回 “false”。

Date

返回日期的文字表示法。

Error

返回一个包含相关错误信息的字符串。

Function

返回如下格式的字符串,其中 functionname 是被调用 toString 方法函数的名称:function functionname( ) { [native code] }

Number

返回数字的文字表示。

String

返回 String 对象的值。

默认

返回 “[object objectname]”,其中 objectname 是对象类型的名称。

5、String(mix)函数,将任何类型的值转换为字符串,其规则为:

(1)如果有toString()方法,则调用该方法(不传递radix参数)并返回结果

(2)如果是null,返回”null”

(3)如果是undefined,返回”undefined”

6、Boolean(mix)函数,将任何类型的值转换为布尔值。

以下值会被转换为false:false、”"、0、NaN、null、undefined,其余任何值都会被转换为true。

二、隐式转换

在某些情况下,即使我们不提供显示转换,Javascript也会进行自动类型转换,主要情况有:

1、 用于检测是否为非数值的函数:isNaN(mix)

isNaN()函数,经测试发现,该函数会尝试将参数值用Number()进行转换,如果结果为“非数值”则返回true,否则返回false。

2、递增递减操作符(包括前置和后置)、一元正负符号操作符

这些操作符适用于任何数据类型的值,针对不同类型的值,该操作符遵循以下规则(经过对比发现,其规则与Number()规则基本相同):

(1)如果是包含有效数字字符的字符串,先将其转换为数字值(转换规则同Number()),在执行加减1的操作,字符串变量变为数值变量。

(2)如果是不包含有效数字字符的字符串,将变量的值设置为NaN,字符串变量变成数值变量。

(3)如果是布尔值false,先将其转换为0再执行加减1的操作,布尔值变量数值变成变量。

(4)如果是布尔值true,先将其转换为1再执行加减1的操作,布尔值变量变成数值变量。

(5)如果是浮点数值,执行加减1的操作。

(6)如果是对象,先调用对象的valueOf()方法,然后对该返回值应用前面的规则。如果结果是NaN,则调用toString()方法后再应用前面的规则。对象变量变成数值变量。

3、 加法运算操作符

加号运算操作符在Javascript也用于字符串连接符,所以加号操作符的规则分两种情况:

如果两个操作值都是数值,其规则为:

(1)如果一个操作数为NaN,则结果为NaN

(2)如果是Infinity+Infinity,结果是Infinity

(3)如果是-Infinity+(-Infinity),结果是-Infinity

(4)如果是Infinity+(-Infinity),结果是NaN

(5)如果是+0+(+0),结果为+0

(6)如果是(-0)+(-0),结果为-0

(7)如果是(+0)+(-0),结果为+0

如果有一个操作值为字符串,则:

如果两个操作值都是字符串,则将它们拼接起来。

如果只有一个操作值为字符串,则将另外操作值转换为字符串,然后拼接起来。

如果一个操作数是对象、数值或者布尔值,则调用toString()方法取得字符串值,然后再应用前面的字符串规则。对于undefined和null,分别调用String()显式转换为字符串。

可以看出,加法运算中,如果有一个操作值为字符串类型,则将另一个操作值转换为字符串,最后连接起来。

4、 乘除、减号运算符、取模运算符

这些操作符针对的是运算,所以他们具有共同性:如果操作值之一不是数值,则被隐式调用Number()函数进行转换。具体每一种运算的详细规则请参考ECMAScript中的定义。

5、 逻辑操作符(!、&&、||)

逻辑非(!)操作符首先通过Boolean()函数将它的操作值转换为布尔值,然后求反。

  • 逻辑与(&&)操作符,如果一个操作值不是布尔值时,遵循以下规则进行转换:

(1)如果第一个操作数经Boolean()转换后为true,则返回第二个操作值,否则返回第一个值(不是Boolean()转换后的值)

(2)如果有一个操作值为null,返回null

(3)如果有一个操作值为NaN,返回NaN

(4)如果有一个操作值为undefined,返回undefined

  • 逻辑或(||)操作符,如果一个操作值不是布尔值,遵循以下规则:

(1)如果第一个操作值经Boolean()转换后为false,则返回第二个操作值,否则返回第一个操作值(不是Boolean()转换后的值)

(2)对于undefined、null和NaN的处理规则与逻辑与(&&)相同

6、 关系操作符(<, >, <=, >=)

与上述操作符一样,关系操作符的操作值也可以是任意类型的,所以使用非数值类型参与比较时也需要系统进行隐式类型转换:

(1)如果两个操作值都是数值,则进行数值比较

(2)如果两个操作值都是字符串,则比较字符串对应的字符编码值

(3)如果只有一个操作值是数值,则将另一个操作值转换为数值,进行数值比较

(4)如果一个操作数是对象,则调用valueOf()方法(如果对象没有valueOf()方法则调用toString()方法),得到的结果按照前面的规则执行比较

(5)如果一个操作值是布尔值,则将其转换为数值,再进行比较

注:NaN是非常特殊的值,它不和任何类型的值相等,包括它自己,同时它与任何类型的值比较大小时都返回false。

7、 相等操作符(==)

相等操作符会对操作值进行隐式转换后进行比较:

(1)如果一个操作值为布尔值,则在比较之前先将其转换为数值

(2)如果一个操作值为字符串,另一个操作值为数值,则通过Number()函数将字符串转换为数值

(3)如果一个操作值是对象,另一个不是,则调用对象的valueOf()方法,得到的结果按照前面的规则进行比较

(4)null与undefined是相等的

(5)如果一个操作值为NaN,则相等比较返回false

(6)如果两个操作值都是对象,则比较它们是不是指向同一个对象

 

 


以上是关于如何从INTERVAL类型转换为NUMBER类型的主要内容,如果未能解决你的问题,请参考以下文章

包装类

如何将自定义类型转换为原始类型?

java中如何将number类型变量转成int类型

oracle decimal(10,0)类型强制转换sql char(10) 如何转换

将 Number 类型的值隐式强制转换为不相关的类型 flash.display:MovieClip

C#,字符串“Number”转换为数值等于多少?为啥用Convert。ToDouble()无法转换???