Oracle数据库中的转换函数

  在操作表中的数据时,经常需要将某个数据从一种类型转换为另外一种数据类型,这时就需要转换类型函数。比如常见的,有把具有“特定格式”字符串转换为日期、把数字转换为字符等。在不同的数据类型之间完成转换,有隐式转换和显式转换之分。 隐式转换: SQL> select * from emp where hiredate = 17-11月-81 显示转换: SQL> select to_char(sysdate, yyyy-mm-dd hh24:mi:ss) from dual 隐式转换的由 Oracle 数据库完成(前提条件是被转换的对象是可以转换的),显式转换通过转换函数完成。 如果隐式、显式都可以使用,应该首选显式,这样可以省去 Oracle 的解析过程。

常用的转换函数如下表所示:
函数 说明 CHARTORWIDA(s) 将字符串s转换为RWID类型 CONVERT(s,aset[, bset]) 将字符串s由bset字符集转换为aset字符集 ROWIDTOCHAR() 将ROWID数据类型转换为CHAR类型 TO_CHAR(x[, format]) 将表达式转换为字符串,format表示字符串格式 TO_DATE(s[, format[lan]]) 将字符串s转换为date类型,format表示字符串格式,lan表示使用的语言 TO_NUMBER(s[, format[lan]]) 该函数返回字符串s代表的数字,返回值按照format格式进行显示,format表示字符串格式,lan表示所使用的的语言
转换函数的具体应用

1. TO_CHAR(x[, format]) 函数

SQL> select sysdate as 默认日期格式, to_char(sysdate, yyyy-mm-dd) as 转换后日期 from dual;

默认日期格式 转换后日期 2019/5/25 0 2019-05-25

2. TO_NUMBER(s[, format[lan]]) 函数

SQL> select to_number(18f, xxx) as 十进制数 from dual;

十进制数 399

3. TO_DATE(s[, format[lan]]) 函数

SQL> select to_date(2019-05-25,yyyy-mm-dd) as 日期 from dual;

日期 2019/5/25

经验分享 程序员 微信小程序 职场和发展