HelloWouldH 2023-03-07 11:28 采纳率: 100%
浏览 23
已结题

使用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的问题。

  • 写回答

4条回答 默认 最新

  • 「已注销」 2023-03-07 11:51
    关注

    参考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。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 3月15日
  • 已采纳回答 3月7日
  • 创建了问题 3月7日

悬赏问题

  • ¥70 刚刚看到一个人的网站居然是通过cname访问的
  • ¥15 Attributeerror:super object has no attribute '__sklearn_tags__'_'
  • ¥15 逆置单链表输出不完整
  • ¥15 宇视vms-B200-A16@R启动不了,如下图所示,在软件工具搜不到,如何解决?(操作系统-linux)
  • ¥500 寻找一名电子工程师完成pcb主板设计(拒绝AI生成式答案)
  • ¥15 关于#mysql#的问题:UNION ALL(相关搜索:sql语句)
  • ¥15 matlab二位可视化能否针对不同数值范围分开分级?
  • ¥15 已经创建了模拟器但是不能用来运行app 怎么办😭自己搞两天了
  • ¥15 关于#极限编程#的问题,请各位专家解答!
  • ¥20 win11账户锁定时间设为0无法登录