原标题:Oracle 数据类型转换之 varchar2,number,date

大家好;

大家都知道,Oracle SQL 在where子查询中,“=” 关系的两侧,数据类型要一致,才能查询数据;有时候,我们不小心, Varchar2 “=” Number; 虽然有时候不会提示【数据库设置选项】,但是Oracle 在查询之前,是会有隐形的数据类型转换的;

在数据库查询引擎执行时,会多一步隐形数据转换;降低了查询性能,有时候还会破坏索引,是已经创建的索引无效;

比如:

表:cux_20_bd_Customers.customer_id 是varchar2,存储的纯数字;

低效:

SELECT rc.customer_number,

rc.customer_name

FROM ra_customers rc,

cux_20_bd_customers r2

WHERE 1 = 1

AND r2.customer_id = rc.customer_id;-- 隐形数据转换

r2.customer_id 会先转换成number,然后在连接;

高效:

SELECT rc.customer_number,

rc.customer_name

FROM ra_customers rc,

cux_20_bd_customers r2

WHERE 1 = 1

AND to_number( r2.customer_id) = rc.customer_id;-- 显性数据转换;

若 r2.customer_id 有索引;则 索引被破坏;查询将全表扫描;

Oracle 中三大类型与隐式数据类型转换

(1)varchar2变长/char定长-->number,例如:'123'->123

(2)varchar2/char-->date,例如:'25-4月-15'->'25-4月-15'

(3)number---->varchar2/char,例如:123->'123'

(4)date------>varchar2/char,例如:'25-4月-15'->'25-4月-15'

Oracle 如何隐式转换:

1)“=”号二边的类型是否相同

2)如果“=”号二边的类型不同,尝试的去做转换

3)在转换时,要确保合法合理,否则转换会失败,例如:12月不会有32天,一年中不会有13月

【1】查询1980年12月17日入职的员工(方式一:日期隐示式转换)

select * from emp where hiredate = '17-12月-80';

【2】使用to_char(日期,'格"常量"式')函数将日期转成字符串,显示如下格式:2015 年 04 月 25 日 星期六

select to_char(sysdate,'yyyy" 年 "mm" 月 "dd" 日 "day') from dual;

【3】使用to_char(日期,'格式')函数将日期转成字符串,

显示如格式:2015-04-25今天是星期六 15:15:15

select to_char(sysdate,'yyyy-mm-dd"今天是"day hh24:mi:ss') from dual;

select to_char(sysdate,'yyyy-mm-dd"今天是"day HH12:MI:SS AM') from dual;

【4】使用to_char(数值,'格式')函数将数值转成字符串,

显示如下格式:$1,234

select to_char(1234,'$9,999') from dual;

【5】使用to_char(数值,'格式')函数将数值转成字符串,显示如下格式:¥1,234select to_char(1234,'$9,999') from dual;

select to_char(1234,'L9,999') from dual;

【6】使用to_date('字符串','格式')函数,查询1980年12月17日入职的员工(方式二:日期显式转换)

select * from emp where hiredate =

to_date('1980年12月17日','yyyy"年"mm"月"dd"日"');

select * from emp where hiredate =

to_date('1980#12#17','yyyy"#"mm"#"dd');

select * from emp where hiredate =

to_date('1980-12-17','yyyy-mm-dd');

【7】使用to_number('字符串')函数将字符串‘123’转成数字123

select to_number('123') from dual;

注意:

select '123' + 123 from dual;

结果:246

select '123' || 123 from dual;

结果:123123

今天到此为止,希望对大家有帮助;

责任编辑:

oracle tovarchar2_Oracle 数据类型转换之 varchar2,number,date相关推荐

  1. sql数据类型转换oracle,ORACLE SQL数据类型转换

    ORACLE SQL数据类型转换 开发工具与关键技术:Oracle sql*plus PLSQL Developer 撰写时间:2019年3月25日 下面要说的是,如何将不同类型的数据进行转换处理 这 ...

  2. ORACLE SQL数据类型转换

    ORACLE SQL数据类型转换 开发工具与关键技术:Oracle sql*plus PLSQL Developer 撰写时间:2019年3月25日 下面要说的是,如何将不同类型的数据进行转换处理 这 ...

  3. oracle java数据类型转换函数_Oracle基础——单行函数(类型转换函数)

    零点起飞学Oracle 正版现货 155.4元 (需用券) 去购买 > Oracle基础--单行函数(类型转换函数) 在执行运算的过程中,经常需要把一种数据类型转换成另一种数据类型. 数据转换分 ...

  4. oracle varchar2() 占几个字母,Oracle number date varchar2字段类型占用空间大小

    oracledate类型占用存储空间是7个字节oraclevarchar2类型占用存储空间是每个字符占用一个字节oraclenumber类型占用存储空间是几个字节number最少占用两个字节, ora ...

  5. MYSQL 与 Oracle 之间的数据类型转换

    2009-07-21 MYSQL 与 Oracle 之间的数据类型转换 关键字: mysql, oracle, 数据类型, 转换 Table 2-4 Default Data Type Mapping ...

  6. Oracle 语言分类 数据类型 数据类型转换 常用函数 集合操作 子查询

    SQL分类 SQL(Structure Query Language)语言是数据库的核心语言.SQL语言共分为四大类:数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL.1 ...

  7. Oracle数据类型转换

    oracle有三种最基本的数据类型,即字符型.数值型.日期型.同时提供类型转换函数 1)to_char 数值.日期->字符型 语法:to_char(num|date,[format mask], ...

  8. Oracle 数据类型转换详解(显示 + 隐式)

    文章目录 1 概述 2 显式转换 2.1 to_char 2.2 to_date 2.3 to_number 3 隐式转换 1 概述 #mermaid-svg-fwPpwf4wV1eBbxmS .la ...

  9. oracle到hive数据类型转换

    oracle和hive中的数据类型存在差异,在oracle集成数据到hive中这样的场景下,我们希望在hive中的数据是贴源的,所以在hive中希望创建和oracle结构一致的表. oracle到hi ...

最新文章

  1. Java开发最常犯的10个错误,打死都不要犯!
  2. 关于antd Select 限制选择个数的解决方案
  3. java math 类_Java Math类静态长轮(double d)示例
  4. C/C++:Windows编程—Inline Hook内联钩子(下)
  5. python-数据容器-有序容器与无序容器
  6. bzoj1079 [SCOI2008]着色方案
  7. 【SQL】实验三 视图管理和使用
  8. 前端预览PDF:PDFObject、PDF.js
  9. 任小龙 mysql笔记_任小龙java基础的Excel笔记(完整版)
  10. Redis高频面试题(欢迎来学习讨论)
  11. 从“大恐怖”展望AI未来,未来人类会好吗?
  12. java list 索引值_List中固定某个索引的值-简单替换位置
  13. python股票价格预测_python用线性回归预测股票价格
  14. 优盘里面的文件夹变0字节也打不开文件的解决方法
  15. LINUX在线安装jdk11
  16. 买笔记本电脑如何避坑之完结篇
  17. 硬盘引导恢复(mbr主引导记录的恢复)
  18. 机器学习实验(一):运用机器学习(Kmeans算法)判定家庭用电主因
  19. 魅族html查看程序退出,魅族MX2左下角屏幕失灵自动点击怎么解决_魅族2程序自动返回退出的原因...
  20. MySQL免安装版安装与环境变量配置

热门文章

  1. Git LFS的使用
  2. 希尔和归并排序的异同
  3. Scikit-Learn简单操作
  4. 文字过多以省略号代替,放在文字上会显示title信息提示
  5. Android 完全退出程序,以及再按一次返回键退出程序
  6. 常用的JavaScript验证正则表达式
  7. java文件怎么一行一行读,Java 读文件内容如何显示在一行上
  8. python从零开始到放弃_Python 协程从零开始到放弃
  9. flowable 中文文档_滴滴实习收获 | 产品经理就是写文档和开会沟通的吗?
  10. smallint占用几个字节_面试官问我:Object o = new Object() 占用了多少个字节?