暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle中的不可见字符处理案例一则

原创 eygle 2008-06-25
1083
今天遇到一则案例,问题是数据库中看来完全相同的字段却存在长度差异。



通过lengthb以及dump我们可以知道问题所在:

SQL> select trim(log.sname),dump(log.sname),lengthb(log.sname)

  2    from st.LIMPORT_LOG log

  3  where log.dfee > date '2008-06-22'

  4    and log.dfee < date '2008-06-23'

  5    and log.sspname like '263%'

  6  group by log.sname,dump(log.sname);



TRIM(LOG.SNAME)  DUMP(LOG.SNAME)                                                LENGTHB(LOG.SNAME)

------------------- ----------- ----------------------------------------------

263网络通信        Typ=1 Len=15: 50,54,51,205,248,194,231,205,168,208,197,0,0,0,0  15

263网络通信        Typ=1 Len=11: 50,54,51,205,248,194,231,205,168,208,197          11



使用DUMP函数我们发现,在有问题的数据中,数据末尾存在几个字符0,0,0,0,也就是多出了几个字符。

正是这多出的几个字符导致了存储异常。



那么这个0代表什么字符呢?在ASCII编码表里我们可以看到这对应了一个不可见字符,这是数据入库时的异常导致的:








-The End-

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论