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的一个别名 子集关系



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值