我的编程空间,编程开发者的网络收藏夹
学习永远不晚

oracle中如何使用CAST函数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

oracle中如何使用CAST函数

本篇文章为大家展示了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集合函数一起使用。

上述内容就是oracle中如何使用CAST函数,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

oracle中如何使用CAST函数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

oracle中cast函数用法

cast 函数用于将值显式转换为另一个数据类型,语法为 cast(expression as data_type)。用法示例包括:将数值转换为字符串、字符串转换为日期和字符串转换为数字。转换选项包括数值类型、字符类型、日期类型和布尔类型。O
oracle中cast函数用法
2024-04-30

Sql中CAST函数怎么使用

在SQL中,CAST函数用于将一个数据类型转换为另一个数据类型。其语法如下:CAST(expression AS data_type)其中,expression是想要进行转换的表达式或列名,data_type是想要将expression
2023-10-26

oracle中to_char函数如何使用

在Oracle中,TO_CHAR函数用于将一个数值、日期或时间转换为字符串。它具有以下语法:TO_CHAR(expr, format, [nlsparam])其中,- expr是要转换的数值、日期或时间。- format是转换的格式模板。可
2023-08-30

Mysql CAST函数的具体使用

目录语法参数说明示例练习案例CAST函数用于将值从一种数据类型转换为表达式中指定的另一种数据类型语法CAST(value AS datatype)AS关键字用于分隔android两个参数,在AS之前的是要处理的数据,在AS之后的是要转
2022-08-12

oracle中replace函数如何使用

在Oracle中,`REPLACE`函数的语法如下:```sqlREPLACE(string, search_string, replacement_string)```该函数用于替换指定字符串中的某个子字符串为另一个字符串。参数说明如下:
2023-10-07

MySQL中cast函数的用法是什么

在MySQL中,CAST()函数用于将一个值转换为指定的数据类型。其语法如下:CAST(expression AS data_type)其中,expression是要转换的值,data_type是要转换为的数据类型。例如,将一个字符串转换
MySQL中cast函数的用法是什么
2024-04-09

sqlserver中cast函数的作用是什么

在SQL Server中,CAST函数用于将一个数据类型转换为另一个数据类型。例如,如果您有一个字符串类型的列,但希望将其转换为整数类型,则可以使用CAST函数来实现这一转换。CAST函数提供了灵活性,使您能够在不同数据类型之间进行转换,以
sqlserver中cast函数的作用是什么
2024-03-05

SQL中cast函数的作用是什么

cast函数用于将一个数据类型转换为另一个数据类型。它可以用来将一个列或值转换为不同的数据类型,例如将一个字符串转换为整数,或将一个日期转换为字符串。通过使用cast函数,可以确保数据在进行计算或比较时具有正确的数据类型,从而避免出现错误或
SQL中cast函数的作用是什么
2024-04-09

sqlserver中cast函数的用法是什么

在SQL Server中,CAST函数用于将一个表达式转换为指定的数据类型。其基本语法如下:CAST ( expression AS data_type )其中,expression是要转换的表达式,data_type是要转换成的数据类型
sqlserver中cast函数的用法是什么
2024-04-09

编程热搜

目录