iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >oracle中如何使用CAST函数
  • 2144
分享到

oracle中如何使用CAST函数

2024-04-02 19:04:59 2144人浏览 泡泡鱼
摘要

本篇文章为大家展示了oracle中如何使用CAST函数,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。CAST()函数可以进行数据类型的转换。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函数,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: oracle中如何使用CAST函数

本文链接: https://www.lsjlt.com/news/56996.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • oracle中如何使用CAST函数
    本篇文章为大家展示了oracle中如何使用CAST函数,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。CAST()函数可以进行数据类型的转换。CAST()函数的参数有...
    99+
    2024-04-02
  • oracle中cast函数用法
    cast 函数用于将值显式转换为另一个数据类型,语法为 cast(expression as data_type)。用法示例包括:将数值转换为字符串、字符串转换为日期和字符串转换为数字。...
    99+
    2024-04-30
    oracle
  • MySQL 数据库中 CAST 函数如何使用?
    1:CAST函数       CAST 函数是 SQL 中的一种类型转换函数,它用于将一个数据类型转换为另一个数据类型。 2:常用的 CAST 函数的方法 2.1  将字符串转换为数字类型 CAST('123' AS INT) -- 将字符...
    99+
    2023-09-02
    java 开发语言
  • Sql中CAST函数怎么使用
    在SQL中,CAST函数用于将一个数据类型转换为另一个数据类型。其语法如下: CAST(expression AS data_typ...
    99+
    2023-10-26
    Sql
  • MySQL中的cast()函数用法
    CAST()函数,把一个字段转成另一个字段,主要转化的是字段的类型 其语法为:cast(字段名 as 转换的类型 )                 转换的类型共有: CHAR            字符型            ...
    99+
    2023-09-01
    java 数据库
  • oracle中replace函数如何使用
    在Oracle中,`REPLACE`函数的语法如下:```sqlREPLACE(string, search_string,...
    99+
    2023-10-07
    oracle
  • Oracle中decode函数如何使用
    这篇文章将为大家详细讲解有关Oracle中decode函数如何使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。函数介绍:DECODE函数是ORACLE P...
    99+
    2024-04-02
  • oracle中to_char函数如何使用
    在Oracle中,TO_CHAR函数用于将一个数值、日期或时间转换为字符串。它具有以下语法:TO_CHAR(expr, fo...
    99+
    2023-08-30
    oracle
  • Oracle中nvl( )函数如何使用
    Oracle中nvl( )函数如何使用,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、介绍: nvl( ) 函数从两个表达式返...
    99+
    2024-04-02
  • oracle中如何使用decode函数
    今天就跟大家聊聊有关oracle中如何使用decode函数,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  一、DECODE函数是ORACLE PL...
    99+
    2024-04-02
  • Contains 函数如何在Oracle 中使用
    本篇文章为大家展示了Contains 函数如何在Oracle 中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1. 查询住址在北京的学生SELECT&n...
    99+
    2024-04-02
  • oracle中如何使用正则函数
    oracle中如何使用正则函数,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。使用这些函数可以在字符串中搜索字符模式。例如,假设...
    99+
    2024-04-02
  • 如何在PHP中使用Oracle函数
    随着企业应用软件的开发,许多企业开始使用Oracle数据库来存储数据。在PHP开发中,Oracle数据库有着广泛的应用,因为它是一个可靠的高性能的数据库。为了更好地使用Oracle数据库,你需要了解如何在PHP中使用Oracle函数。在本文...
    99+
    2023-05-18
    函数 PHP Oracle
  • sqlserver中cast函数的用法是什么
    在SQL Server中,CAST函数用于将一个表达式转换为指定的数据类型。其基本语法如下: CAST ( expression A...
    99+
    2024-04-09
    sqlserver
  • sqlserver中cast函数的作用是什么
    在SQL Server中,CAST函数用于将一个数据类型转换为另一个数据类型。例如,如果您有一个字符串类型的列,但希望将其转换为整数...
    99+
    2024-03-05
    sqlserver
  • Oracle cast函数对用户数据进行类型转换
    一、cast函数    cast函数的作用是对用户输入的数据进行数据类型转换,比如用户数据的数据时number类型,小数位数是3位,我们可以将用户数据转换成×××数据...
    99+
    2024-04-02
  • MySQL中cast函数的用法是什么
    在MySQL中,CAST()函数用于将一个值转换为指定的数据类型。其语法如下: CAST(expression AS data_ty...
    99+
    2024-04-09
    MySQL
  • oracle rank函数如何使用
    在Oracle中,RANK函数用于计算一个结果集中每个行的排名。它可以根据指定的列对结果集进行排序,并为每个行分配一个排名值。RAN...
    99+
    2023-08-30
    oracle
  • oracle中如何使用connectbyprior递归函数
    这篇文章将为大家详细讲解有关oracle中如何使用connectbyprior递归函数,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。  oracle中con...
    99+
    2024-04-02
  • SQL中cast函数的作用是什么
    cast函数用于将一个数据类型转换为另一个数据类型。它可以用来将一个列或值转换为不同的数据类型,例如将一个字符串转换为整数,或将一个...
    99+
    2024-04-09
    SQL
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作