Welcome 微信登录

首页 / 数据库 / MySQL / Oracle基础教程:单行函数—类型转换函数

不同数据类型之间的转换
在赋值语句中数据类型会隐式转换,隐式转换应当尽量避免,因为写出来的SQL难理解,随着时间流逝自己都很难理解
特别是嵌入到大型程序中时,另外,Oracle升级会修改隐式转换的规则,这会使程序移植遇到问题.
尤其是索引列不能使用隐式转换 那样就不走索引了赋值语句中oracle的自动转换规则:
 1.将变长字符型(varchar2)或定长字符型(char)转换成数值型(number)
 2.将变长字符型(varchar2)或定长字符型(char)转换成日期型(date)
 3.将数值型(number)转换成变长字符型(varchar2)
 4.将日期型(date)转换成变长字符型(varchar2)表达式中oracle的自动转换规则:
 1.将变长字符型(varchar2)或定长字符型(char)转换成数值型(number)
 2.将变长字符型(varchar2)或定长字符型(char)转换成日期型(date) 转换成功的条件:
 在将字符型数据转换成数字型时,要保证字符型数据为有效的数.
 在将字符型数据转换成日期型时,要保证字符型数据位有效的日期.
 
SQL> select ename,sal from emp where sal > "4000";ENAME    SAL
---------- ----------
KING   5000SQL>   拿字符和数字比较 oracle自动将字符串转成了数字SQL> select ename,hiredate from emp where hiredate = "17-NOV-81";ENAME    HIREDATE
---------- ------------------
KING    17-NOV-81SQL>   拿字符串充当日期 oracle自动将字符串转成了日期不能直接转换
 数值型和日期型之间不能直接转换,必须将其中之一先转换为字符型,之后再转换为另一种类型 显示转换函数:
 to_char
 to_number
 to_date
  
to_char(日期,"fmt") 
 将日期型数据转换成字变长字符串.fmt为日期格式
 日期格式必须用单引号扩起来
 常用的时间格式:
  YYYY  数字年
  YEAR  英文年
  MM    数字月
  MONTH 英文月
  DY    缩写的星期
  DAY   完整的星期
  DD    数字日期
  hh    12小时
  HH24  24小时
  MI    分钟
  SS    秒idle> select ename,to_char(hiredate,"YYYY-MM-DD") from emp where ename="SCOTT";ENAME    TO_CHAR(HI
---------- ----------
SCOTT    1987-04-19idle>  将日期型转换成了字符型to_char(数字,"fmt")
 将数字转换成变长字符串.fmt为数字格式
 9 一个数字  给定的9个数不足 会显示#
 0 显示前导0
 $ 美元符号
 L 本地货币符号
 . 小数点
 , 千位符
  • 1
  • 2
  • 下一页
Oracle基础教程:单行函数—日期类型函数Oracle基础教程:单行函数—null值处理函数相关资讯      oracle数据库教程 
  • Oracle raw数据类型介绍  (01/29/2013 10:05:53)
  • 监听器注册与ORA-12514 错误分析  (11/13/2012 14:30:08)
  • Oracle SQL的cursor理解  (11/13/2012 14:16:17)
  • Oracle 如何强制刷新Buffer Cache  (01/29/2013 10:02:46)
  • dblink致Oracle库的SCN变成两库的  (11/13/2012 14:24:41)
  • Linux操作系统下完全删除Oracle数  (11/13/2012 08:25:52)
本文评论 查看全部评论 (0)
表情: 姓名: 字数

版权所有©石家庄振强科技有限公司2024 冀ICP备08103738号-5 网站地图