Cast方法oracle,oracle 中cast方法的使用

cast方法可以转换数据类型。

一般情况下,我们很少在sql中对结果集的字段修改类型,这个完全可以放到java程序中进行处理。

当然oracle的cast也提供了这个功能。

个人感觉字符串与数字类型的转换放在sql中完全没必要,字符串和日期的转换在sql中大多使用to_date,to_char,

其他类型转换好像没用到过。

想来这个cast转换类型可以用在排序上,或者转换类型后进行统计,总的来说用处不大。

/* select * from lsy_user_develop t */

/* 字段类型*/

/*

USER_ID CHAR(32)

REAL_NAME VARCHAR2(150)

CREATE_TIME DATE

USER_NO LONG

PHONE VARCHAR2(20)

ADDRESS VARCHAR2(150)

SEX VARCHAR2(4)

AGE NUMBER

*/

语法:

CAST ( expression AS data_type )

select a.user_id,a.real_name,

cast(a.age as VARCHAR2(10) ) ,

cast(a.create_time as VARCHAR2(20) )

from lsy_user_develop a;

SELECT CAST('123.4' AS integer) from dual

SELECT CAST('123.4' AS decimal(9,2)) from dual

//这里要注意oracle的数据类型short/int/long/float/double/decimal

oracle 中没有这些数据类型,数值类型是number。不过可以兼容,实际上oracle是把这两种类型转换成了number,

只是对number做了长度上的调整。如果你是基于oracle的pl/sql, 也是使用number的。

short/int/long/float/double 了

在数据库中,统一为 number(m,n) 的形式

INT、INTEGER 是 NUMBER 的受限子类型(只表示整数),相当于 NUMBER(38)。

NUMBER 类型最大可表示 38 个十进制位的数值。

INTEGER或者INT、SMALLINT 则是 ANSI SQL 的数据类型,它对应的ORALCE数据类型是NUMBER(38)

integer 是number的一个别名 子集关系

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值