首页 文章 精选 留言 我的

精选列表

搜索[oracle],共6892篇文章
优秀的个人博客,低调大师

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 resultfrom dual; RESULT --- 123 返回值是整型值123。 --如果试图将一个代表小数的字符串转换为整型值,又会出现什么情况呢? SELECT CAST('123.4' AS int)as resultfrom dual; RESULT -------- 123 SELECT CAST('123.6' AS int)as resultfrom 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 20130263 201303 77 20130468 20130597 201306 62 201307 87 --奖学金表。 --奖学金表规定了名次,每个名次的人数和奖金。 create table scholarship (www.ry-mir.com 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; 名次人数 奖金 ---------- --------------------------------------- ---------- 11 1000 22 500 33 100 现在要根据成绩表的成绩降序排列,按奖学金表的名额确定排名和奖金。排名时不考虑相同成绩。 排名的结果应该如下: 学号 成绩 名次 奖金 201305 97 1 1000 20130787 2 500 201303 77 2 500 201304683 100 201301673100 20130263 3100 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集合函数一起使用。

资源下载

更多资源
优质分享App

优质分享App

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Nacos

Nacos

Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service 的首字母简称,一个易于构建 AI Agent 应用的动态服务发现、配置管理和AI智能体管理平台。Nacos 致力于帮助您发现、配置和管理微服务及AI智能体应用。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据、流量管理。Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。

Spring

Spring

Spring框架(Spring Framework)是由Rod Johnson于2002年提出的开源Java企业级应用框架,旨在通过使用JavaBean替代传统EJB实现方式降低企业级编程开发的复杂性。该框架基于简单性、可测试性和松耦合性设计理念,提供核心容器、应用上下文、数据访问集成等模块,支持整合Hibernate、Struts等第三方框架,其适用范围不仅限于服务器端开发,绝大多数Java应用均可从中受益。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。

用户登录
用户注册