marxist

类型转换概述

在赋值语句中数据类型会隐式转换,隐式转换应当尽量避免,因为写出来的SQL难理解,随着时间流逝自己都很难理解。特别是嵌入到大型程序中时,另外,oracle升级会修改隐式转换的规则,这会使程序移植遇到问题。尤其是索引列不能使用隐式转换,这样就不走索引

 

赋值语句中oracle的自动转换规则:
  • 将变长字符型(varchar2)或定长字符型(char)转换成数值型(number)
  • 将变长字符型(varchar2)或定长字符型(char)转换成日期型(date)
  • 将数值型(number)转换成变长字符型(varchar2)
  • 将日期型(date)转换成变长字符型(varchar2)

表达式中oracle的自动转换规则:

  • 将变长字符型(varchar2)或定长字符型(char)转换成数值型(number)
  • 将变长字符型(varchar2)或定长字符型(char)转换成日期型(date)

转换成功的条件:

  • 在将字符型数据转换成数字型时,要保证字符型数据为有效的数。
  • 在将字符型数据转换成日期型时,要保证字符型数据位有效的日期。
----拿字符和数字比较 oracle自动将字符串转成了数字
SQL> select ename,sal from emp where sal > \'4000\';

ENAME  SAL
---------- ----------
KING 5000


----拿字符串充当日期 oracle自动将字符串转成了日期
SQL> select ename,hiredate from emp where hiredate = \'17-NOV-81\';

ENAME   HIREDATE
---------- ------------------
KING   17-NOV-81
数值型和日期型之间不能直接转换,必须将其中之一先转换为字符型,之后再转换为另一种类型

显示转换函数:

  • to_char
  • to_number
  • to_date

to_char(日期,\'fmt\')

将日期型数据转换成字变长字符串.fmt为日期格式,日期格式必须用单引号扩起来。
常用的时间格式:
  • YYYY  数字年
  • YEAR  英文年
  • MM    数字月
  • MONTH 英文月
  • DY    缩写的星期
  • DAY   完整的星期
  • DD    数字日期
  • hh    12小时
  • HH24  24小时
  • MI    分钟
  • SS    秒
----将日期型转换成了字符型
SQL> select ename,to_char(hiredate,\'YYYY-MM-DD\') from emp where ename=\'SCOTT\';

ENAME   TO_CHAR(HI
---------- ----------
SCOTT   1987-04-19

to_char(数字,\'fmt\')

将数字转换成变长字符串,fmt为数字格式。
  • 9 表示一个数字  给定9个数不足,会显示#
  • 0 显示前导0
  • $ 美元符号
  • L 本地货币符号
  • . 小数点
  • , 千位符
SQL> select to_char(sal*12,\'$99,999.99\') from emp where ename =\'SCOTT\';

TO_CHAR(SAL
-----------
 $36,000.00

SQL> select to_char(sal*12,\'L99,999.00\',\'NLS_CURRENCY=RMB\') from emp where ename =\'SCOTT\';

TO_CHAR(SAL*12,L99,
--------------------
 RMB36,000.00

SQL> select to_char(sal*12,\'L99,999.00\',\'NLS_CURRENCY=¥\') from emp where ename =\'SCOTT\';

TO_CHAR(SAL*12,L99,
--------------------36,000.00

to_char 还可以将10进制数转换成16进制数

SQL> select to_char(10,\'xxxx\') from dual;
 
TO_CH
-----
    a

to_number(\'字符串\',\'数字格式\')

字符串一定要符合数字的格式
SQL> select to_number(\'678.88\',\'9999999.99\') from dual;

TO_NUMBER(\'678.88\',\'9999999.99\')
--------------------------------
     678.88

to_number 也可以将16进制转换成10进制

SQL> select to_number(\'a\',\'xxxx\') from dual;

TO_NUMBER(\'A\',\'XXXX\')
---------------------
     10

TO_DATE(\'字符串\',\'日期格式\')

字符串一定要符合日期格式
hiredate = to_date(\'2010-10-10\',\'YYYY\')

SQL> select to_DATE(\'2010-10-10 20:44:37\',\'YYYY-MM-DD HH24:MI:SS\') from dual;

TO_DATE(2010-10-10
-------------------
2010-10-10 20:44:37

分类:

技术点:

相关文章:

  • 2022-12-23
  • 2021-06-22
  • 2022-12-23
  • 2022-12-23
  • 2018-09-08
  • 2022-02-21
  • 2021-08-30
  • 2021-12-05
猜你喜欢
  • 2022-02-06
  • 2021-12-05
  • 2021-12-05
  • 2021-12-05
  • 2021-12-05
  • 2021-12-05
相关资源
相似解决方案