oracle中CAST函数使用简介

CAST()函数可以进行数据类型的转换。

CAST()函数的参数有两部分,源值和目标数据类型,中间用AS关键字分隔。

以下例子均通过本人测试。

一、转换列或值

语法:cast( 列名/值 as 数据类型 )

用例:

1)、转换列

--将empno的类型(number)转换为varchar2类型。

select cast(empno as varchar2(10)) as empno from emp;

EMPNO
----------
7369
7499
7521
...

2)、转换值

--将字符串转换为整型。
SELECT CAST(‘123‘ AS int) as result from dual;

RESULT
 ---

123
返回值是整型值123。

--如果试图将一个代表小数的字符串转换为整型值,又会出现什么情况呢?
SELECT CAST(‘123.4‘ AS int) as result from dual;

RESULT
--------

123

SELECT CAST(‘123.6‘ AS int) as result from dual;

RESULT
--------

124
从上面可以看出,CAST()函数能执行四舍五入操作。

--截断小数

SELECT CAST(‘123.447654‘ AS decimal(5,2)) as result from dual;

RESULT
-----------
 123.45
decimal(5,2)表示值总位数为5,精确到小数点后2位。
SELECT CAST(‘123.4‘ AS decimal) as result from dual;
结果是一个整数值:
123
二、转换一个集合

语法:cast( multiset(查询语句) as 数据类型 )

1)转换成table

例子:

--学生成绩表

create table stu_score
(stu_no varchar2(50),--学号
 score number--总分
 );
insert into stu_score values(‘201301‘,67);
insert into stu_score values(‘201302‘,63);
insert into stu_score values(‘201303‘,77);
insert into stu_score values(‘201304‘,68);
insert into stu_score values(‘201305‘,97);
insert into stu_score values(‘201306‘,62);
insert into stu_score values(‘201307‘,87);
commit;

------------------------------------------

select * from stu_score;

学号        分数

--------  ----------
201301      67
201302       63
201303      77
201304       68
201305       97
201306      62
201307      87

--奖学金表。

--奖学金表规定了名次,每个名次的人数和奖金。

create table scholarship
(
stu_rank  varchar(10),--名次
stu_num    int,--限定人数
money      number--奖金
);
insert into scholarship values(‘1‘,1,‘1000‘);
insert into scholarship values(‘2‘,2,‘500‘);
insert into scholarship values(‘3‘,3,‘100‘);
commit;

-----------------------------------------------

select * from scholarship;

名次                                          人数    奖金
---------- --------------------------------------- ----------
1                                              1      1000
2                                              2       500
3                                              3       100

现在要根据成绩表的成绩降序排列,按奖学金表的名额确定排名和奖金。排名时不考虑相同成绩。
排名的结果应该如下:
学号        成绩      名次  奖金
201305       97      1      1000
201307       87          2       500
201303       77         2        500
201304        68          3        100
201301        67          3         100
201302        63      3         100

SELECT c.stu_no,c.score,b.stu_rank,b.money
 FROM (SELECT c.*,ROW_NUMBER() OVER(ORDER BY score DESC) rn FROM stu_score c) c
     ,(SELECT b.stu_rank,b.money,ROW_NUMBER() OVER(ORDER BY b.stu_rank) rn
        FROM scholarship b
           , TABLE( CAST( MULTISET( SELECT NULL
                                     FROM DUAL
                                  CONNECT BY LEVEL <= b.stu_num
                                  )
                           AS SYS.ODCIVARCHAR2LIST ) 
                          )
      ) b
WHERE c.rn=b.rn;

执行结果如下:

STU_NO                                                 SCORE     STU_RANK       MONEY
-------------------------------------------------- ----------        ----------         ----------
201305                                                    97                    1               1000
201307                                                    87                    2                500
201303                                                    77                    2                500
201304                                                    68                    3                100
201301                                                    67                    3                100
201302                                                    63                    3                100

通过对比发现,确实达到了目的。

此外cast还能转化成collection,varray,此时都需要记过multiset集合函数一起使用。

时间: 2024-10-01 04:29:17

oracle中CAST函数使用简介的相关文章

Oracle 中 decode 函数用法

Oracle 中 decode 函数用法 含义解释:decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下:IF 条件=值1 THEN RETURN(翻译值1)ELSIF 条件=值2 THEN RETURN(翻译值2) ......ELSIF 条件=值n THEN RETURN(翻译值n)ELSE RETURN(缺省值)END IFdecode(字段或字段的运算,值1,值2,值3) 这个函数运行的结果是,当字段或字段的运算的值等于值1时,该函数返回值

Oracle中SYS_CONNECT_BY_PATH函数的妙用

在Oracle中,SYS_CONNECT_BY_PATH函数主要作用是可以把一个父节点下的所有子节点通过某个字符进行区分,然后连接在一个列中显示. AD: Oracle中SYS_CONNECT_BY_PATH函数是非常重要的函数,下面就为您介绍一个使用SYS_CONNECT_BY_PATH函数的例子,实例如下: create table test (a varchar2(10),b varchar2(10)); INSERT INTO TEST (A, B) VALUES ('1', '我');

oracle中extract()函数----用于截取年、月、日、时、分、秒

oracle中extract()函数从oracle 9i中引入,用于从一个date或者interval类型中截取到特定的部分 语法如下: extract ( { year | month | day | hour | minute | second } | { timezone_hour | timezone_minute } | { timezone_region | timezone_abbr } from { date_value | interval_value } ) 只可以从一个da

Oracle中REGEXP_SUBSTR函数(转)

Oracle中REGEXP_SUBSTR函数 Oracle中REGEXP_SUBSTR函数的使用说明: 题目如下:在oracle中,使用一条语句实现将'17,20,23'拆分成'17','20','23'的集合. REGEXP_SUBSTR函数格式如下:function REGEXP_SUBSTR(String, pattern, position, occurrence, modifier)__srcstr :需要进行正则处理的字符串__pattern :进行匹配的正则表达式__positio

Oracle使用cast() 函数的一个BUG

今天在用Oracle时无意发现一个小问题,就是使用cast函数转换类型时,出现文字被截断现象,现贴出来,如下: Select  Cast('未填写' As Nvarchar2(16)) As Hg  From Dual Select  Cast('未填写内容' As Nvarchar2(16)) As Hg  From Dual  Select  Cast('未填写什么' As Nvarchar2(16)) As Hg  From Dual 结论:部分中文被截断,比如测试用的'请选择','无核管

oracle中nvl()函数

oracle的nvl函数的使用方法 通过查询获得某个字段的合计值,假设这个值位null将给出一个预设的默认值 select nvl(sum(t.dwxhl),1) from tb_jhde t where zydm=-1 这里关心的nvl的使用方法,nvl(arg,value)代表假设前面的arg的值为null那么返回的值为后面的value 如: NVL(a,b)就是推断a是否是NULL,假设不是返回a的值.假设是返回b的值 通过查询获得某个字段的合计值,假设这个值位null将给出一个预设的默认

Oracle中SYS_CONNECT_BY_PATH函数的使用

在Oracle中,SYS_CONNECT_BY_PATH函数主要作用是可以把一个父节点下的所有子节点通过某个字符进行区分,然后连接在一个列中显示. sys_connect_by_path(字段名, 2个字段之间的连接符号),注意这里的连接符号不要使用逗号,oracle会报错,如果一定要用,可以使用replace替换一下, 方法如下 REPLACE(字段名,原字符,','). 还有,这个函数使用之前必须先建立一个树,否则无用. select  length(mc),mc,length( repla

oracle中的函数

ORACLE中函数          Oracle已经内建了许多函数,不同的函数有不同的作用和用法,有的函数只能作用在一个记录行上,有的能够作用在多个记录行上,不同的函数可能处理不同的数据类型.常见的有两类,单行函数和分组函数 . 单行函数: 单行函数 分类 函数 功能 示例 字符函数 LPAD(<c1>,<i>[,<c2>]) 在字符串c1的左边添加字符串c2直到c1字符串的长度等于i. SELECT  LPAD('Hello!',9,1) leftpad,RPAD(

Oracle 中,函数如何返回结果集

在Oracle中,用函数返回结果集有时候要用到,下面是demo: create or replace type t_test as object ( id integer, create_time date, object_name varchar2(60) ); create or replace type t_test_table as table of t_test; 1.用数组的方式 create or replace function f_test(n in number defaul