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