经常在前辈们的SQL中可以看到CAST,例如:WITH T AS(SELECT LEVEL||" " L FROM DUAL CONNECT BY LEVEL<=5),A(A,V) AS(SELECT
CAST(L AS VARCHAR(30)),1 FROM TUNION ALLSELECT A||L,V+1 FROM A, T WHERE INSTR(A,L)=0 AND V<5)SELECT * FROM A;例如上面的with递归语句,但是CAST因为用的比较少,今天就先给自己扫个盲了,引用Oracle的官方文档中对于CAST的描述如下:
CAST
CAST converts values from one data type to another.Return ValueThe data type specified by
type_name.SyntaxCAST(expr AS type_name)Arguments
expr can be an expression in one of the data types.
type_name is one of the data types listed in Table1-2,"Dimensional Data Types".Table 3-1 shows which data types can be cast into which other built-in data types.
NUMBER includes
NUMBER,
DECIMAL, and
INTEGER.
DATETIME includes
DATE,
TIMESTAMP,
TIMESTAMP WITH TIMEZONE, and
TIMESTAMP WITH LOCAL TIMEZONE.
INTERVAL includes
INTERVAL DAY TO SECOND and
INTERVAL YEAR TO MONTH.Table 3-1 Compatible Data Types
Example
CAST("123.4567" AS NUMBER(10,2)) returns the value 123.46.通过上面的描述,我们就可以知道CAST可以将一种类型转换为另外一种类型。比如,将字符串类型转换为NUMBER(10,2)类型,而不仅仅是限于使用用to_number、to_char()以及to_date()类型,上述表Table 3-1代表CAST是否能够用于该类型的相互转换。例子调用:ChenZw>
SELECT CAST("123.4567" AS NUMBER(10,2)) AS NUM FROM DUAL;更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12Oracle执行计划中的连接方式nested loops join、sort merge joinn、hash join设置Oralce自动内存管理相关资讯 Oracle Cast 本文评论 查看全部评论 (0)