现在是时候看看这条记录的物理数据了:
天啊,竟然是0,真不晓得是怎么存进去的。问题终于知道在那了,但是要如何解决呢?最简单的方法就是将这个0替换掉,于是使用下列语句测试:
select replace(demc, char(0), '') as demc from tblgc_jc_de
但是不行,原因是replace函数找不到0这个字符,因为它查找是按两个字节来找的,所以直接在SQL Server上找也找不到这个字符,替换也替换不了。但是,我又想了一下,能不能使用二进制来查找和替换?看了一下资料,使用下面的SQL语句能找出0在该字段的位置:
查是能查出来了,但是我发现replace函数还是不能用,除非是替换4位,也就是0x0038。
最后实在无奈,只能直接把有这个特殊字符的地段截掉一个文字,也就是连那个38也不要了:
select
case when charindex(convert(varbinary(1),0x00),convert(varbinary(200),demc)) > 0
then substring(demc,1,len(demc)-1)
else demc
end as DEMC
from tblgc_jc_de
这就是我现在用的最终解决方案,因为我查询过,4万多条记录中只有8条有这个0在字段里面。所以就算截掉一个文字并影响程序的功能和显示。
虽然我现在写出来很多步骤看似走的很顺,其实这个问题我用了几天时间了,主要是找问题所在耗费了不少时间。现在给出此文希望广大朋友在找这些问题时多个方向,因为存储在字段中的特殊字符不一定就是常规的回车换行符,也有可能是其它字符,在此大家互相学习提高吧。