监控安装 ERP

系统集成论坛

 找回密码
 注册通行证

QQ登录

只需一步,快速开始

路由器交换机防火墙系统集成商城 优质产品采购平台
查看: 1517|回复: 0
打印 上一主题 下一主题

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

[复制链接]

35

主题

552

帖子

963

积分

正式员工

跳转到指定楼层
1
发表于 2010-4-19 09:18:41 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
华为金牌代理
字符格式

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与其他字符连接,如

declare a char(3):='ab';  b char(6):='ab';  begin dbms_output.put_line(a||'c'); --ab c 其中ab和c之间有一个空格  dbms_output.put_line(b||'c'); --ab c 其中ab和c之间有4个空格  if a||'c' >b||'c' then dbms_output.put_line(1); //成立,采用非语义比较。  end if;  end; 3.在使用char的sql中,或表类型定义中,确定是定长的才使用,否则可能导致相关问题,如果有char的,比如要查询,如where charstring='abcd',后面的字面量最好和char长度一致

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

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册通行证

x
您需要登录后才可以回帖 登录 | 注册通行证

本版积分规则

联系我们| 手机版|系统集成论坛 ( 京ICP备11008917号 )

GMT+8, 2024-11-24 11:39 , Processed in 0.114620 second(s), 29 queries .

系统集成论坛

BBS.XTJC.COM

快速回复 返回顶部 返回列表