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笔试面宝典》读者群 小麦苗的微店
.............................................................................................................................................



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