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])将字符串sbset字符集转换为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
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值