PostgreSQL copy 时提示:ERROR: invalid byte sequence for encoding "UTF8": 0xb3

Posted 狂神314

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PostgreSQL copy 时提示:ERROR: invalid byte sequence for encoding "UTF8": 0xb3相关的知识,希望对你有一定的参考价值。

测试时使用三种文件格式:

ISO-8859

Netpbm PBM image

ASCII

if [ $(file $filename|grep -c "ISO-8859") -gt 0 ]
then
   echo "ISO-8859" psql -c "copy $schemaname.$tbname from ‘$dirname/$filename‘ with(format ‘csv‘, delimiter ‘, encoding ‘ISO-8859-1‘)" $dbname elif [ $(file $filename|grep -c "ASCII") -gt 0 ]
then
   echo $format psql -c "copy $schemaname.$tbname from ‘$dirname/$filename‘ with(format ‘csv‘, delimiter ‘, encoding ‘UTF-8‘)" $dbname else psql -c "copy $schemaname.$tbname from ‘$dirname/$filename‘ with(format ‘csv‘, delimiter ‘, encoding ‘ISO-8859-1‘)" $dbname

这种处理方式在文件格式为ASCII时,copy中途仍然会出现编码错误提示。

ERROR: invalid byte sequence for encoding "UTF8": 0xb3 

 

最后摸索发现不管什么格式,都指定为ISO-8859-1就能处理。

 

全包容的编码格式,都能处理:

psql -c "copy $schemaname.$tbname from ‘$dirname/$filename‘ with(format ‘csv‘, delimiter ‘, encoding ‘ISO-8859-1‘)" $dbname

 





以上是关于PostgreSQL copy 时提示:ERROR: invalid byte sequence for encoding "UTF8": 0xb3的主要内容,如果未能解决你的问题,请参考以下文章

Postgresql COPY CSV ERROR:最后一个预期列之后的额外数据

postgresql copy from 字符串转换为时间类型

错误:在 psql 中使用 \copy 时缺少列数据

postgresql数据库 copy命令导入表不成功

postgresql数据库删除时提示回话 sessions using the database

使用 PostgreSQL 时使用 COPY 命令处理错误