今天执行一个简单的sql,总是提示有语法错误,可以确定sql的语法是没有问题的,只可能是sql文本字符串有问题,使用xxd这个二进制文件查看工具,它可以将文件以十六进制对应输出。 简化复现一下,原始文件invisible.txt:
xxd
select order_id, price from orders where id = 12345
执行命令 xxd invisible.txt 输出:
xxd invisible.txt
00000000: 7365 6c65 6374 200a 6f72 6465 725f 6964 select .order_id 00000010: 2c20 7072 6963 650a 6672 6f6d 206f 7264 , price.from ord 00000020: 6572 730a 7768 6572 65c2 a00a 6964 203d ers.where...id = 00000030: 2031 3233 3435 0a 12345.
可以看到where后面除了换行符0a前面还有不可见字符,查询utf-8字符编码表: http://www.utf8-chartable.de/unicode-utf8-table.pl?utf8=0x 发现0xc2 0xa0这个code point对应的字符是NO-BREAK SPACE,不换行空格是一个空格字符,用途是禁止自动换行。HTML页面显示时会自动合并多个连续的空白字符(whitespace character),但该字符是禁止合并的,因此该字符也称作“硬空格”(hard space、fixed space)。 这个字符导致sql异常,可以将它删除: tr -d "\302\240" < invisible.txt > visible.txt
where
0a
0xc2 0xa0
NO-BREAK SPACE
tr -d "\302\240" < invisible.txt > visible.txt
http://www.utf8-chartable.de/unicode-utf8-table.pl?utf8=0x https://zh.wikipedia.org/wiki/UTF-8 http://www.voidcn.com/article/p-fthfycuu-mk.html http://xiangwangfeng.com/2011/05/02/UTF-8%E8%BD%ACGBK%E7%9A%84%E6%82%B2%E5%89%A7-%E7%89%B9%E6%AE%8A%E5%AD%97%E7%AC%A6C2A0/
如果觉得我的文章对您有用,请在支付宝公益平台找个项目捐点钱。 @sxzhou Aug 23, 2017