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