1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 数据库 - 正文

君子好学,自强不息!

本文面向想学习Oracle知识的各位数据库管理员,希望通过本文,让大家对于Oracle中时间、数字、字符格式有更深刻的理解。 数据库也向您推荐《Oracle数据库开发应用指南 》来帮助您更好的理解本文。

字符格式

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
achar(3):='ab'; 
bchar(6):='ab'; 
begin
dbms_output.put_line(a||'c');--abc其中ab和c之间有一个空格 
dbms_output.put_line(b||'c');--abc其中ab和c之间有4个空格 
ifa||'c'>b||'c'then
dbms_output.put_line(1);//成立,采用非语义比较。 
endif; 
end;

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

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

本文来源:1818IP

本文地址:https://www.1818ip.com/post/11586.html

免责声明:本文由用户上传,如有侵权请联系删除!

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。