oracle中CAST函数使用简介 admin 2023-05-26 11:00:02 篇首语:本文由小编为大家整理,主要介绍了oracle中CAST函数使用简介相关的知识,希望对你有一定的参考价值。 CAST()函数可以进行数据类型的转换。CAST()函数的参数有两部分,源值和目标数据类型,中间用AS关键字分隔。以下例子均通过本人测试。一、转换列或值语法:cast( 列名/值 as 数据类型 )用例:1)、转换列--将empno的类型(number)转换为varchar2类型。select cast(empno as varchar2(10)) as empno from emp;EMPNO----------736974997521...2)、转换值--将字符串转换为整型。SELECT CAST("123" AS int) as result from dual; RESULT --- 123返回值是整型值123。--如果试图将一个代表小数的字符串转换为整型值,又会出现什么情况呢?SELECT CAST("123.4" AS int) as result from dual; RESULT-------- 123SELECT 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.45decimal(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 67201302 63201303 77201304 68201305 97201306 62201307 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 10002 2 5003 3 100现在要根据成绩表的成绩降序排列,按奖学金表的名额确定排名和奖金。排名时不考虑相同成绩。排名的结果应该如下:学号 成绩 名次 奖金201305 97 1 1000201307 87 2 500201303 77 2 500201304 68 3 100201301 67 3 100201302 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 ) ) ) bWHERE c.rn=b.rn;执行结果如下:STU_NO SCORE STU_RANK MONEY-------------------------------------------------- ---------- ---------- ----------201305 97 1 1000201307 87 2 500201303 77 2 500201304 68 3 100201301 67 3 100201302 63 3 100通过对比发现,确实达到了目的。此外cast还能转化成collection,varray,此时都需要记过multiset集合函数一起使用。以上是关于oracle中CAST函数使用简介的主要内容,如果未能解决你的问题,请参考以下文章 MySQL用户远程访问授权 论文解读SCNN 用于交通场景理解的空间CNN 您可能还会对下面的文章感兴趣: 相关文章 浏览器打不开网址提示“ERR_CONNECTION_TIMED_OUT”错误代码的解决方法 如何安装ocx控件 VMware的虚拟机为啥ip地址老是自动变化 vbyone和EDP区别 linux/debian到底怎么重启和关机 苹果平板键盘被弄到上方去了,如何调回正常? 机器学习常用距离度量 如何查看kindle型号