IT猫扑网:您身边最放心的安全下载站! 最新更新| 软件分类| 专题汇总| 手机版

您当前所在位置:IT猫扑网 > 数据库 > Oracle > Oracle中时间、数字、字符格式详解

Oracle中时间、数字、字符格式详解

时间:2015-06-28 00:00 来源:IT猫扑网|http://www.itmop.com/ 作者:网管联盟 我要评论(0)

  本文面向想学习Oracle知识的各位数据库管理员,希望通过本文,让大家对于Oracle中时间、数字、字符格式有更深刻的理解。51CTO数据库也向您推荐《Oracle数据库开发应用指南 <http://database.51cto.com/art/200511/12457.htm>》来帮助您更好的理解本文。

  字符格式

  Oracle中字符串的比较有两类

  1.填补空格的语义比较

  2.非填补空格的语义比较

  填补空格的语义比较:

  如果两个字符串有不同的长度,Oracle首先会在短的字符串那边末尾添加空格,直到两个字符串长度相等。

  Oracle然后按字符顺序比较两个字符串的值,如果发现到不同的字符,则按字段顺序认定大小,如果没有发现不同字符,Oracle则认为两个字符串相等。这个规则意味着,如果只是尾号中有不同数目的空格,那么则认为两个字符串是相等的。如'a '='a'.

  使用填补空格的语义比较,Oracle只针对char,nchar,字面量,或user函数返回的值。

  非填补空格的语义比较:

  Oracle通过字符顺序比较两个字符串的值。如果发现到字符值大的则大。如果两个字符串长度不同,则发现到字符值大的则大,否则长度大的则大,比如'b'>'ab','ab'>'a'.如果长度相等,并且各个位置字符相同,则认定为相等。

  使用非填补空格的语义比较,Oracle针对varchar2和nvarchar2。

  

  1.注意使用char,char是定长类型,不足长度末尾补空格,比较大小采用填补空格的语义比较

  2.注意char与其他字符连接,如

  1.declare

  2.a char(3):='ab';

  3.b char(6):='ab';

  4.begin

  5.dbms_output.put_line(a||'c'); --ab c 其中ab和c之间有一个空格

  6.dbms_output.put_line(b||'c'); --ab c 其中ab和c之间有4个空格

  7.if a||'c' >b||'c' then

  8.dbms_output.put_line(1); //成立,采用非语义比较。

  9.end if;

  10.end;

  3.在使用char的sql中,或表类型定义中,确定是定长的才使用,否则可能导致相关问题,如果有char的,比如要查询,如where charstring='abcd',后面的字面量最好和char长度一致

  4.其实char 的效率和varchar2没有什么区别。tom测试过。

关键词标签:Oracle

相关阅读 误删Oracle数据库实例的控制文件 为UNIX服务器设置Oracle全文检索 Oracle数据库如何查找删除重复的SQL语句 Oracle导入导出数据库的语法 oracle数据库安装预环境一键处理脚本 oracle常用DBA命令

文章评论
发表评论

热门文章 利用Oracle分区表来减少磁盘I/O冲突 利用Oracle分区表来减少磁盘I/O冲突 Oracle数据库优化之数据库磁盘I/O Oracle数据库优化之数据库磁盘I/O 讲解Oracle复制技术的分布式系统同步应用 讲解Oracle复制技术的分布式系统同步应用 刷新Oracle缓存 刷新Oracle缓存 oracle 8080与TOMCAT默认端口冲突 oracle 8080与TOMCAT默认端口冲突 DATAGUARD的日志应用服务 DATAGUARD的日志应用服务

相关下载

人气排行 oracle中使用SQL语句修改字段类型-oracle修改SQL语句案例 Oracle中使用alter table来增加,删除,修改列的语法 ORACLE SQL 判断字符串是否为数字的语句 ORACLE和SQL语法区别归纳(1) oracle grant 授权语句 ORACLE修改IP地址后如何能够使用 如何加速Oracle大批量数据处理 Oracle删除表的几种方法 Oracle 10g创建表空间和用户并指定权限 Oracle连接数太多报错-ORA-12516错误 Oracle字符串截取 连接Oracle数据库的Hibernate配置文件