本文面向想学习Oracle知识的各位数据库管理员,希望通过本文,让大家对于Oracle中时间、数字、字符格式有更深刻的理解。数据库也向您推荐《Oracle数据库开发应用指南》来帮助您更好的理解本文。
成都创新互联专业为企业提供旌德网站建设、旌德做网站、旌德网站设计、旌德网站制作等企业网站建设、网页设计与制作、旌德企业网站模板建站服务,10余年旌德做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
字符格式
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测试过。
【编辑推荐】
新闻标题:Oracle中时间、数字、字符格式详解
文章地址:http://www.shufengxianlan.com/qtweb/news15/267365.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联