您当前的位置: 首页 >  oracle

Oracle中CAST函数使用简介

发布时间:2017-12-26 11:26:46 ,浏览量:0

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集合函数一起使用。

About Me

.............................................................................................................................................

● 本文作者:小麦苗,部分内容整理自网络,若有侵权请联系小麦苗删除

● 本文在itpub(http://blog.itpub.net/26736162/abstract/1/)、博客园(http://www.cnblogs.com/lhrbest)和个人微信公众号(xiaomaimiaolhr)上有同步更新

● 本文itpub地址:http://blog.itpub.net/26736162/abstract/1/

● 本文博客园地址:http://www.cnblogs.com/lhrbest

● 本文pdf版、个人简介及小麦苗云盘地址:http://blog.itpub.net/26736162/viewspace-1624453/

● 数据库笔试面试题库及解答:http://blog.itpub.net/26736162/viewspace-2134706/

● DBA宝典今日头条号地址:http://www.toutiao.com/c/user/6401772890/#mid=1564638659405826

.............................................................................................................................................

● QQ群号:230161599(满)、618766405

● 微信群:可加我微信,我拉大家进群,非诚勿扰

● 联系我请加QQ好友(646634621),注明添加缘由

● 于 2017-12-01 09:00 ~ 2017-12-31 22:00 在魔都完成

● 文章内容来源于小麦苗的学习笔记,部分整理自网络,若有侵权或不当之处还请谅解

● 版权所有,欢迎分享本文,转载请保留出处

.............................................................................................................................................

● 小麦苗的微店:https://weidian.com/s/793741433?wfr=c&ifr=shopdetail

● 小麦苗出版的数据库类丛书:http://blog.itpub.net/26736162/viewspace-2142121/

.............................................................................................................................................

使用微信客户端扫描下面的二维码来关注小麦苗的微信公众号(xiaomaimiaolhr)及QQ群(DBA宝典),学习最实用的数据库技术。

   小麦苗的微信公众号      小麦苗的DBA宝典QQ群2     《DBA笔试面宝典》读者群       小麦苗的微店

.............................................................................................................................................

ico_mailme_02.png DBA笔试面试讲解群 《DBA宝典》读者群 欢迎与我联系

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26736162/viewspace-2149297/,如需转载,请注明出处,否则将追究法律责任。

关注
打赏
1688896170
查看更多评论

暂无认证

  • 0浏览

    0关注

    108180博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文
立即登录/注册

微信扫码登录

0.0762s