Oracle数据库中的转换函数

    xiaoxiao2023-06-15  176

      在操作表中的数据时,经常需要将某个数据从一种类型转换为另外一种数据类型,这时就需要转换类型函数。比如常见的,有把具有“特定格式”字符串转换为日期、把数字转换为字符等。在不同的数据类型之间完成转换,有隐式转换和显式转换之分。 隐式转换: 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

    最新回复(0)