Error[8]: Undefined offset: 37, File: /www/wwwroot/outofmemory.cn/tmp/plugin_ss_superseo_model_superseo.php, Line: 121
File: /www/wwwroot/outofmemory.cn/tmp/plugin_ss_superseo_model_superseo.php, Line: 473, decode(

oracle转换函数有哪些

oracle的转换函数有:to_char()、to_date()、to_number()、CAST()、TO_MULTI_BYTE()、to_single_byte()、CONVERT()、UNISTR()、COMPOSE()等等。

本教程 *** 作环境:Windows7系统、Oracle 11g版、Dell G3电脑。

转换函数可用于将一种数据类型转换为另一种数据类型。

oracle转换函数有哪些

1、to_char()函数:将DATE或者NUMBER转换为字符串

2、 to_date()函数:将number、char转换为date

3、 to_number()函数:将char转换为number

4、CAST(expr AS type_name)函数:用于将一个内置数据类型或集合类型转变为另一个内置数据类型或集合类型。

expr为列名或值,type_name数据类型。

SELECT CAST('123.4' AS int) from dual;

结果:123

可进行四舍五入 *** 作:

SELECT CAST('123.447654' AS decimal(5,2)) as result from dual;

decimal(5,2)表示值总位数为5,精确到小数点后2位。

结果:123.45

5、TO_MULTI_BYTE(c1)函数:将字符串c1中的半角转化为全角。TO_MULTI_BYTE和TO_SINGLE_BYTE是相反的两个函数.

select to_multi_byte('高A') text from dual;

结果:

6、to_single_byte(c1)函数:将字符串c1中的全角转化为半角。

select to_single_byte('高A') text from dual;

结果:

7、TIMESTAMP_TO_SCN(timestamp)函数:用于根据输入的timestamp返回所对应的scn值,其中timestamp用于指定日期时间。

作为对于闪回 *** 作(flashback)的一个增强,Oracle10g提供了函数对于SCN和时间戳进行相互转换。

select timestamp_to_scn(sysdate) scn from dual;

结果:9709105

8、SCN_TO_TIMESTAMP(number)函数:根据输入的scn值返回对应的大概日期时间,其中number用于指定scn值。

select to_char(scn_to_timestamp(9709105), 'yyyy-mm-dd hh24:mi:ss')from dual;

结果:2018-05-21 18:23:35

9、CONVERT(string,dest_set[,source_set])函数:将字符串string从source_set所表示的字符集转换为由dest_set所表示的字符集.如果source_set没有被指定,它缺省的被设置为数据库的字符集。

ZHS16GBK表示采用GBK编码格式、16位(两个字节)简体中文字符集

WE8ISO8859P1(西欧、8位、ISO标准8859P1编码)

AL32UTF8(其中AL代表ALL,指适用于所有语言)、zhs16cgb231280

select convert('中国','US7ASCII','WE8ISO8859P1') "conversion" from dual;

结果:O??u

10、TRANSLATE(str1 USING zfj)函数:将字符串转变为数据库字符集(char_cs)或民族字符集(nchar_cs)

Select TRANSLATE(‘中国’ using nchar_cs) from dual;

结果:中国

11、ASCIISTR(s)函数:将任意字符集的字符串转变为数据库字符集的ASCII字符串。

Select ASCIISTR ('1A_中文')  from dual;

结果:1A_\4E2D\6587

12、UNISTR(str1)函数:输入字符串返回相应的UNICODE字符

Select UNISTR ('E2D'),UNISTR ('87'),UNISTR ('00'),UNISTR ('13、COMPOSE(string)函数E0') from dual;

结果:中 文 ` à

Select COMPOSE('a'||unistr('00'))  from dual;
:这个函数以UNICODE字符串为参数,返回一个规范化的字符串。

比如,它可以接受一个字母和一个组合标记,比如说‘a'(Unicode 字符0097)和沉音符(Unicode 字符0300),然后创建一个单独的由两个标记组合而成的字符(à)。

14、DECOMPOSE(string)函数:

结果:à

SELECT DECOMPOSE ('Châteaux') FROM DUAL;
返回一个Unicode字符串。它是string的规范分解。

15、CHARTOROWID(c1)函数:

结果:Cha^teaux

SELECT chartorowid('AAAADeAABAAAAZSAAA') FROM DUAL;
将字符数据类型CHAR或VARCHAR2转换为ROWID值.参数c1是长度为18的字符串,必须符合rowid格式.CHARTOROWID是ROWIDTOCHAR的反函数。

在Oracle中,每一条记录都有一个rowid,rowid在整个数据库中是唯一的,rowid确定了每条记录是在Oracle中的哪一个数据文件、块、行上。在重复的记录中,可能所有列的内容都相同,但rowid不会相同。

16、ROWIDTOCHAR(rowid)函数:

结果:AAAADeAABAAAAZSAAA

SELECT ROWIDTOCHAR(rowid) FROM DUAL;
转换rowid值为varchar2类型,rowid固定参数,返回长度为18的字符串。

17、INTERVAL 'integer [- integer]' {YEAR | MONTH} [(precision)][TO {YEAR | MONTH}]函数

结果:AAAAB0AABAAAAOhAAA

select INTERVAL '123-2' YEAR(3) TO MONTH from dual;
:该数据类型常用来表示一段时间差,注意时间差只精确到年和月。

precision为年或月的精确域, 有效范围是0到9, 默认值为2.

18、HEXTORAW(string)函数:

表示: 123年2个月, "YEAR(3)" 表示年的精度为3, 可见"123"刚好为3为有效数值, 如果该处YEAR(n), n<3就会出错, 注意默认是2
结果:+123-02

select hextoraw('abcdef') from dual;
将string一个十六进制构成的字符串转换为二进制RAW数值.String中的每两个字符表示了结果RAW中的一个字节.HEXTORAW和RAWTOHEX为相反的两个函数.当出现比f大的字母时(以a最小z最大)就会报错

19、RAWTOHEX(rawvalue)函数:

结果:ABCDEF

select rawtohex('AA') from dual;
将raw串转换为十六进制. rawvalue中的每个字节都被转换为一个双字节的字符串.

20、TO_LOB (long_column)函数:

结果:4141 结果之所以是4141是因为A的ASCII为65,65转换为十六进制就是41。

[+++]将LONG或LONG ROW列的数据转变为相应的LOB类型。

但需要注意的是,TO_LOB一般只用在CREATE TABLE或INSERT TABLE语句后面的子查询中。在其他地方使用会报错,比如UPDATE语句。

推荐教程:《Oracle教程》

以上就是oracle转换函数有哪些的详细内容,)
File: /www/wwwroot/outofmemory.cn/tmp/route_read.php, Line: 126, InsideLink()
File: /www/wwwroot/outofmemory.cn/tmp/index.inc.php, Line: 166, include(/www/wwwroot/outofmemory.cn/tmp/route_read.php)
File: /www/wwwroot/outofmemory.cn/index.php, Line: 29, include(/www/wwwroot/outofmemory.cn/tmp/index.inc.php)

oracle转换函数有哪些_非关系型数据库_内存溢出

oracle转换函数有哪些

oracle转换函数有哪些,第1张

oracle转换函数有哪些

oracle的转换函数有:to_char()、to_date()、to_number()、CAST()、TO_MULTI_BYTE()、to_single_byte()、CONVERT()、UNISTR()、COMPOSE()等等。

本教程 *** 作环境:Windows7系统、Oracle 11g版、Dell G3电脑。

转换函数可用于将一种数据类型转换为另一种数据类型。

oracle转换函数有哪些

1、to_char()函数:将DATE或者NUMBER转换为字符串

2、 to_date()函数:将number、char转换为date

3、 to_number()函数:将char转换为number

4、CAST(expr AS type_name)函数:用于将一个内置数据类型或集合类型转变为另一个内置数据类型或集合类型。

expr为列名或值,type_name数据类型。

SELECT CAST('123.4' AS int) from dual;

结果:123

可进行四舍五入 *** 作:

SELECT CAST('123.447654' AS decimal(5,2)) as result from dual;

decimal(5,2)表示值总位数为5,精确到小数点后2位。

结果:123.45

5、TO_MULTI_BYTE(c1)函数:将字符串c1中的半角转化为全角。TO_MULTI_BYTE和TO_SINGLE_BYTE是相反的两个函数.

select to_multi_byte('高A') text from dual;

结果:

6、to_single_byte(c1)函数:将字符串c1中的全角转化为半角。

select to_single_byte('高A') text from dual;

结果:

7、TIMESTAMP_TO_SCN(timestamp)函数:用于根据输入的timestamp返回所对应的scn值,其中timestamp用于指定日期时间。

作为对于闪回 *** 作(flashback)的一个增强,Oracle10g提供了函数对于SCN和时间戳进行相互转换。

select timestamp_to_scn(sysdate) scn from dual;

结果:9709105

8、SCN_TO_TIMESTAMP(number)函数:根据输入的scn值返回对应的大概日期时间,其中number用于指定scn值。

select to_char(scn_to_timestamp(9709105), 'yyyy-mm-dd hh24:mi:ss')from dual;

结果:2018-05-21 18:23:35

9、CONVERT(string,dest_set[,source_set])函数:将字符串string从source_set所表示的字符集转换为由dest_set所表示的字符集.如果source_set没有被指定,它缺省的被设置为数据库的字符集。

ZHS16GBK表示采用GBK编码格式、16位(两个字节)简体中文字符集

WE8ISO8859P1(西欧、8位、ISO标准8859P1编码)

AL32UTF8(其中AL代表ALL,指适用于所有语言)、zhs16cgb231280

select convert('中国','US7ASCII','WE8ISO8859P1') "conversion" from dual;

结果:O??u

10、TRANSLATE(str1 USING zfj)函数:将字符串转变为数据库字符集(char_cs)或民族字符集(nchar_cs)

Select TRANSLATE(‘中国’ using nchar_cs) from dual;

结果:中国

11、ASCIISTR(s)函数:将任意字符集的字符串转变为数据库字符集的ASCII字符串。

Select ASCIISTR ('1A_中文')  from dual;

结果:1A_\4E2D\6587

12、UNISTR(str1)函数:输入字符串返回相应的UNICODE字符

Select UNISTR ('E2D'),UNISTR ('87'),UNISTR ('00'),UNISTR ('13、COMPOSE(string)函数E0') from dual;

结果:中 文 ` à

Select COMPOSE('a'||unistr('00'))  from dual;
:这个函数以UNICODE字符串为参数,返回一个规范化的字符串。

比如,它可以接受一个字母和一个组合标记,比如说‘a'(Unicode 字符0097)和沉音符(Unicode 字符0300),然后创建一个单独的由两个标记组合而成的字符(à)。

14、DECOMPOSE(string)函数:

结果:à

SELECT DECOMPOSE ('Châteaux') FROM DUAL;
返回一个Unicode字符串。它是string的规范分解。

15、CHARTOROWID(c1)函数:

结果:Cha^teaux

SELECT chartorowid('AAAADeAABAAAAZSAAA') FROM DUAL;
将字符数据类型CHAR或VARCHAR2转换为ROWID值.参数c1是长度为18的字符串,必须符合rowid格式.CHARTOROWID是ROWIDTOCHAR的反函数。

在Oracle中,每一条记录都有一个rowid,rowid在整个数据库中是唯一的,rowid确定了每条记录是在Oracle中的哪一个数据文件、块、行上。在重复的记录中,可能所有列的内容都相同,但rowid不会相同。

16、ROWIDTOCHAR(rowid)函数:

结果:AAAADeAABAAAAZSAAA

SELECT ROWIDTOCHAR(rowid) FROM DUAL;
转换rowid值为varchar2类型,rowid固定参数,返回长度为18的字符串。

17、INTERVAL 'integer [- integer]' {YEAR | MONTH} [(precision)][TO {YEAR | MONTH}]函数

结果:AAAAB0AABAAAAOhAAA

select INTERVAL '123-2' YEAR(3) TO MONTH from dual;
:该数据类型常用来表示一段时间差,注意时间差只精确到年和月。

precision为年或月的精确域, 有效范围是0到9, 默认值为2.

18、HEXTORAW(string)函数:

表示: 123年2个月, "YEAR(3)" 表示年的精度为3, 可见"123"刚好为3为有效数值, 如果该处YEAR(n), n<3就会出错, 注意默认是2
结果:+123-02

select hextoraw('abcdef') from dual;
将string一个十六进制构成的字符串转换为二进制RAW数值.String中的每两个字符表示了结果RAW中的一个字节.HEXTORAW和RAWTOHEX为相反的两个函数.当出现比f大的字母时(以a最小z最大)就会报错

19、RAWTOHEX(rawvalue)函数:

结果:ABCDEF

select rawtohex('AA') from dual;
将raw串转换为十六进制. rawvalue中的每个字节都被转换为一个双字节的字符串.

20、TO_LOB (long_column)函数:

结果:4141 结果之所以是4141是因为A的ASCII为65,65转换为十六进制就是41。

将LONG或LONG ROW列的数据转变为相应的LOB类型。

但需要注意的是,TO_LOB一般只用在CREATE TABLE或INSERT TABLE语句后面的子查询中。在其他地方使用会报错,比如UPDATE语句。

推荐教程:《Oracle教程》

以上就是oracle转换函数有哪些的详细内容,

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/705365.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-23
下一篇 2022-04-23

发表评论

登录后才能评论

评论列表(0条)

保存