`

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集合函数一起使用。

 

/*cast与round的区别***********************/
cast 是进行类型转换的,可以针对各种Oracle数据类型.修改的是用户的数据类型.
round只是修改的数据显示格式. 对数据做四舍五入.
类似的函数还有ceil(取此数据的最小整数). trunc( 取整函数.)

create table t1(a varchar(10));
insert into t1 values ('12.3456');
select round(a) from t1;
--12
select round(a,3) from t1;
--12.346
select cast(a as int) from t1;
--12
select cast(a as number(8,4)) from t1;
--12.3456

 

分享到:
评论

相关推荐

    oracle cast (multiset()as )用法

    通过实例介绍了 cast(multiset() as) 的使用方法,以处理嵌套表的操作

    SQLServer和Oracle的常用函数对比

    - SQLServer中使用`CAST()`函数将浮点数转换为整型。 - Oracle中使用`TRUNC()`函数。 5. **四舍五入** - SQLServer中使用`ROUND()`函数。 - Oracle中同样使用`ROUND()`函数。 6. **e的幂** - SQLServer中使用...

    sql server和oracle中常用函数的比较

    - **SQL Server**与**Oracle**: 分别使用`MAX()`和`MIN()`函数,但在Oracle中可以使用`GREATEST()`和`LEAST()`函数来同时比较多个值。 16. **处理NULL值** - **SQL Server**: 使用`ISNULL()`函数。 - **Oracle**...

    oracle sql内置函数大全

    Oracle SQL内置函数是数据库管理、查询和数据分析中的关键工具,它们极大地增强了SQL语言的功能和...在《Oracle SQL function.ppt》这个文件中,可能包含了更详细的函数介绍、示例和使用技巧,建议查阅以获取更多信息。

    Oracle内建函数大全

    - CONNECT_BY_ROOT/CONNECT_BY_ISLEAF:在层次查询中使用,标识根节点或叶子节点。 10. **系统信息函数** - USER:返回当前用户的名称。 - DBMS_METADATA:获取对象的DDL语句,用于脚本生成。 以上只是Oracle内...

    oracle函数大全中文

    通过"Oracle函数大全(分类显示).chm"这个文档,你可以全面了解并掌握这些函数的使用方法和应用场景,从而更好地在Oracle数据库中进行数据操作和查询。这个资源对于数据库管理员、开发人员和数据分析者来说都是非常...

    oracle函数大全中文api文档

    "Oracle函数大全中文API文档"是一个非常实用的资源,它提供了对Oracle数据库所有内置函数的详尽解释,帮助开发者和DBA快速理解和使用这些函数。 1. **日期与时间函数**: Oracle提供了处理日期和时间的大量函数,...

    oracle常用函数chm版

    这些函数常在SQL查询的GROUP BY语句中使用,进行数据汇总。 6. **分析函数**:分析函数在处理大量数据时非常有用,如`RANK`、`DENSE_RANK`和`ROW_NUMBER`用于生成行序号,`LEAD`和`LAG`可以访问当前行的前一行或后...

    oracle日常函数文档

    以上只是Oracle日常函数的一小部分,实际使用中还有许多其他功能强大的函数,如条件判断函数`DECODE()`,位运算函数,窗口函数等。学习并熟练掌握这些函数,能极大地提升在Oracle数据库中的工作效率,对于初学者来说...

    Oracle内置函数大全.rar

    本资料“Oracle内置函数大全.rar”包含了一份详细的Oracle内置函数讲解,旨在帮助初学者和进阶用户更好地理解和运用这些函数,提升在Oracle数据库操作中的技能。 Oracle内置函数可以分为多种类型,包括算术函数、...

    oracle 和sql Server 函数对比

    Oracle中使用正则表达式的函数如`REGEXP_INSTR`。 27. **子字符串提取** - SQL Server使用`SUBSTRING`函数,Oracle使用`SUBSTR`函数。 - 示例:SQL Server中`SELECT SUBSTRING('abcd', 2, 2)`;Oracle中`SELECT ...

    SQLServer和Oracle常用函数对比

    - **Oracle**: 使用`DBMS_RANDOM.VALUE()`函数,需要从DUAL表中查询。 ```sql SELECT SYS.DBMS_RANDOM.VALUE(0, 1) AS Value FROM DUAL; ``` **13. 取符号** - **SQLServer**: 使用`SIGN()`函数。 ```sql ...

    Oracle函数及常用sql

    本篇文章将深入探讨Oracle中的基本函数以及常用SQL查询,以帮助初学者快速入门,并为日常使用提供参考。 一、Oracle基本函数 1. **字符串函数**: - `CONCAT()`:连接两个或多个字符串。 - `SUBSTR()`:从字符串...

    hive、oracle常用函数对照表

    hive、oracle常用函数对照表

    SQL SEVER与ORACLE常用函数比较

    - SQL Server: 使用`CAST`或`CONVERT`函数将浮点数转换为整数,如 `SELECT CAST(-1.002 AS INT) value;` - Oracle: 使用`TRUNC`函数截取整数部分,如 `SELECT TRUNC(-1.002) value FROM DUAL;` 5. 四舍五入 - ...

    Oracle函数速查手册

    Oracle数据库是世界上最广泛使用的数据库系统之一,其强大的功能和丰富的内置函数是其核心竞争力之一。这份"Oracle函数速查手册"旨在为用户提供一个全面、便捷的参考资源,无论是初学者还是经验丰富的开发者,都能...

    Oracle中常用函数

    ### Oracle中常用函数详解 #### 1. `ABS(a)` - **功能**: 返回绝对值。 - **示例**: ```sql SELECT ABS(-15) "Absolute" FROM DUAL; ``` - **结果**: ``` Absolute ---------- 15 ``` - **解释**: 此函数...

    SQLServer和Oracle的常用函数对比.doc

    4. 截取整数部分:SQL Server通过`CAST()`或`CONVERT()`函数将浮点数转换为整数,Oracle则使用`TRUNC()`函数。 5. 四舍五入:SQL Server和Oracle的`ROUND()`函数用于四舍五入,但Oracle在指定精度时会直接省略...

    SQLServer和Oracle的常用函数

    - `CONCAT()`在SQL Server 2012及以后版本中用于连接字符串,Oracle则可以使用`||`操作符或`CONCAT()`函数。 2. **日期时间函数** - SQL Server的`GETDATE()`返回当前日期和时间,Oracle对应的是`SYSDATE`。 - ...

Global site tag (gtag.js) - Google Analytics