使用Ora2pg迁移数据

Wide character in subroutine entry at C:/Strawberry/perl/site/lib/Ora2Pg.pm line 19762.
DBD::Pg::db do failed: 閿欒: 鍒涘缓涓病鏈夐€夋嫨妯″紡 at C:/Strawberry/perl/site/lib/Ora2Pg.pm line 19762.
Wide character in print at C:/Strawberry/perl/site/lib/Ora2Pg.pm line 14158.
[2023-03-06 16:55:03] FATAL: 閿欒: 鍒涘缓涓病鏈夐€夋嫨妯″紡
Aborting export.

windows环境,使用Ora2pg命令。
导出数据到文件,均正常。
配置config文件后,直接导入pg数据库,导出表结构到本地文件正常。
在pg中创建好表结构之后,导入数据时出现报错。

在网上找了一些帖子,感觉不像是宽字符的问题。
初步判断,应该是perl DBI模块连接PG的问题。

参考GPT和自己的思路,根据错误信息,可能是编码的问题,建议检查以下几点:

1 确认目标数据库的编码是否正确,应该与Ora2pg的配置文件中的目标编码一致。

2 确认数据库连接字符串中的编码是否正确。可以在连接字符串中加入charset=utf8等参数,指定编码类型。

3 检查Ora2pg配置文件中的编码设置是否正确。可以在配置文件中指定源数据库的编码,例如:

ORACLE_NLS_LANG=AMERICAN_AMERICA.UTF8

可以在配置文件中指定目标数据库的编码,例如:

PG_ENCODING=utf8

如果以上都没有解决问题,可以尝试在perl脚本中手动设置编码类型,例如:

use DBI;
$dbh = DBI->connect("dbi:Pg:dbname=test;host=localhost", "username", "password", {pg_enable_utf8 => 1});
$dbh->do("SET CLIENT_ENCODING TO 'UTF8'");

其中,pg_enable_utf8参数用于指定在连接数据库时,使用utf8编码。SET CLIENT_ENCODING用于指定客户端编码为utf8。

该回答引用ChatGPT

根据您提供的信息,错误信息似乎表明在Ora2Pg模块的第19762行中出现了宽字符问题,并且在第14158行中也出现了一个宽字符问题。

在第19762行,它似乎尝试执行一个DBD::Pg的操作,但是因为编码问题而失败了。在第14158行,它尝试打印一些信息,但同样出现了宽字符问题。

考虑到您已经在本地文件中成功导出了数据,我会倾向于您的初步判断,即DBI模块连接PG的问题。您可以尝试检查您的数据库连接设置,确保它们正确地指定了编码。

另外,您也可以尝试将您的程序或模块中所有的字符串都转换成UTF-8编码,这可能有助于解决宽字符问题。可以使用Perl模块的Encode功能进行字符串编码转换。

> 最后,如果以上方法都无法解决问题,建议您在Perl和DBI模块的相关社区或邮件列表上寻求帮助,以获得更专业的支持。

你在使用Ora2pg迁移数据,在pg中创建好表结构之后,导入数据时出现报错。那你就需要檢查你创建的表结构使用的字符集是否正确,还有使用到的引擎是否正确。
其次,使用ora2pg工具不一定能够完全的兼容Oracle的语法,实现转pg,它虽然可以实现类型的自动映射,以及存储过程代码部分自动转换,转换不了的的或者有些定制化的东西,还是需要通过perl来实现。