一、问题描述

  1、采用gdb模板文件,在ArcSDE(数据服务器)中批量创建数据库表(数据迁移)时,用到接口ESRI.ArcGIS.Geodatabase.IGeoDBDataTransfer的方法Transfer时,报错,错误为:Exception from HRESULT: 0x80041538;

  2、在自己电脑上试验没问题,数据服务器上会有该问题;

  3、由于GIS相关问题,相关帮助手册及网上搜了一会,发现几乎没这个问题的相关资料。

二、解决方案

  1、只能从本机环境和数据服务器环境对比上着手,本机环境:Win7 旗舰中文版,Oracle 11g中文版;数据服务器环境:WinServer 2008 R2标准版(别人装的,貌似是英文版的,后来装了中文补丁包,未修改其他设置,输入中文汉字总感觉显示怪怪的),Oracle 11g英文版;

  2、怀疑是编码的问题,便拿ArcCatalog在数据服务器上创建名称为中文的表时,直接报错ORA-00911Invalid Character。于是,便可以断定是字符编码的问题。从两方面着手:

  A、操作系统问题

  windows的问题,在区域和语言设置,把非unicode编码设置为简体中文(设置完成后,重启电脑即可,再输入中文汉字就不觉得怪了)。

  

  B、Oracle数据库问题

  (1)首先查看Oracle的编码,两种方式可以查看(注册表或者sqlplus查询),这两种方式均是借鉴转载别人写的内容

  注册表查看:

  32位在:HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432NODE\ORACLE\HOMExx\NLS_LANG
  (这里是32位的应用程序在64位windows系统中,注册表位置在"WOW6432NODE"下。)
  64位在:HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOMExx\NLS_LANG
  (这里是64位的应用程序在64位windows系统中,注册表位置直接在"SOFTWARE"下。)

  Sqlplus查询:

数据库服务器字符集select * from nls_database_parameters,其来源于props$,是表示数据库的字符集。
  客户端字符集环境select * from nls_instance_parameters,其来源于v$parameter,
  会话字符集环境select * from nls_session_parameters,其来源于v$nls_parameters,表示会话自己的设置,可能是会话的环境变量或者是alter session完成,如果会话没有特殊的设置,将与nls_instance_parameters一致。

  以上两种方式,可得知数据服务器上的Oracle编码为:WE8MSWIN1252(不支持中文)

  

  (2)既然知道了编码WE8MSWIN1252的问题,下面就好解决了,可参考http://blog.itpub.net/22871478/viewspace-1116638/,为了大家看的方法,我把原文转载过来了,如下:

  修改字符集为ZHS16GBK
  SQL> shutdown immediate;
  Database closed.
  Database dismounted.
  ORACLE instance shut down.
  SQL> startup mount
  ORACLE instance started.
   
  Total System Global Area  523108352 bytes
  Fixed Size                  1337632 bytes
  Variable Size             356517600 bytes
  Database Buffers          159383552 bytes
  Redo Buffers                5869568 bytes
  Database mounted.
  SQL> alter session set sql_trace=true;
 
  Session altered.
 
  SQL> alter system enable restricted session;
 
  System altered.
 
  SQL> alter system set job_queue_processes=0;
 
  System altered.
 
  SQL> alter system set aq_tm_processes=0;
 
  System altered.
 
  SQL> alter database open;
 
  Database altered.
 
  SQL> alter database character set ZHS16GBK;
  alter database character set ZHS16GBK
  *
  ERROR at line 1:
  ORA-12712: new character set must be a superset of old character set
 
 
  SQL> alter database character set internal_use ZHS16GBK;
 
  Database altered.
 
  红色部分的错误不影响
  到此修改成功,重启服务,支持中文。
 
  3、问题得以解决。

ArcSDE 数据迁移 Exception from HRESULT: 0x80041538问题及解决方案的更多相关文章

  1. 京东云开发者|京东云RDS数据迁移常见场景攻略

    云时代已经来临,云上很多场景下都需要数据的迁移.备份和流转,各大云厂商也大都提供了自己的迁移工具.本文主要介绍京东云数据库为解决用户数据迁移的常见场景所提供的解决方案. 场景一:数据迁移上云 数据迁移 ...

  2. MySQL数据迁移到MSSQL-以小米数据库为例-测试828W最快可达到2分11秒

    这里采用.NET Framework 4.0以上版本中新出现的 ConcurrentQueue<T> 类 MSDN是这样描述的: ConcurrentQueue<T> 类是一个 ...

  3. 从零自学Hadoop(16):Hive数据导入导出,集群数据迁移上

    阅读目录 序 导入文件到Hive 将其他表的查询结果导入表 动态分区插入 将SQL语句的值插入到表中 模拟数据文件下载 系列索引 本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并 ...

  4. 在Entity Framework 7中进行数据迁移

    (此文章同时发表在本人微信公众号“dotNET每日精华文章”,欢迎右边二维码来关注.) 题记:虽然EF7重新设计了Entity Framework,不过也还是能够支持数据迁移的. Entity Fra ...

  5. HDFS数据迁移解决方案之DistCp工具的巧妙使用

    前言 在当今每日信息量巨大的社会中,源源不断的数据需要被安全的存储.等到数据的规模越来越大的时候,也许瓶颈就来了,没有存储空间了.这时候怎么办,你也许会说,加机器解决,显然这是一个很简单直接但是又显得 ...

  6. zookeeper数据迁移

    在不停机的情况下,实现集群之间数据迁移代码: private void create(ZooKeeper zk1, ZooKeeper zk2, String path) throws Excepti ...

  7. 完美数据迁移-MongoDB Stream的应用

    目录 一.背景介绍 二.常见方案 1. 停机迁移 2. 业务双写 3. 增量迁移 三.Change Stream 介绍 监听的目标 变更事件 四.实现增量迁移 五.后续优化 小结 附参考文档 一.背景 ...

  8. 【DB2】数据迁移

    数据迁移概述 在日常生活中常有数据的导入导出,为此db2提出了很多工具可以选择,export.import.load.db2look.db2move.db2dart,如下图所示: a.最上面虚线框部分 ...

  9. Asp.net Core 2.0+EntityFrameWorkCore 2.0添加数据迁移

    Asp.net Core 由于依赖注入的广泛使用,配置数据迁移,与Asp.net大不相同,本篇介绍一下Asp.net Core添加数据迁移的过程 添加Nuget包 Install-Package Mi ...

随机推荐

  1. 经典的SQL面试题及答案

    ​ ​ ​ ​ ​ ​​​​​ ​ ​​​​​​​​

  2. 用js 实现代码获取下拉框的value值

    var rtl=document.getElementById("selpartyorg"); //获取下拉框对象 var id=rtl.options[rtl.selectedI ...

  3. Golang的 signal

    在实际项目中我们可能有下面的需求: 1.修改了配置文件后,希望在不重启进程的情况下重新加载配置文件: 2.当用 Ctrl + C 强制关闭应用后,做一些必要的处理: 这时候就需要通过信号传递来进行处理 ...

  4. Spring部分面试知识

    对Spring的理解 spring是一个轻量级的开源框架,贯穿持久层.业务逻辑层.控制层.让每一个功能模块都可以独立的分开,降低耦合度,提高代码复用度.spring通过控制反转降低耦合性,一个对象的依 ...

  5. ES6学习笔记(二)-字符串的扩展

    一.字符的 Unicode 表示法 JavaScript 允许采用\uxxxx形式表示一个字符,其中xxxx表示字符的 Unicode 码点. 表示法只限于码点在\u0000~\uFFFF之间的字符, ...

  6. HEOI2017 游记

    你若安好,便是晴天. …… 人就像命运下的蝼蚁,谁也无法操控自己的人生. ——阮行止 …… Day 0 中午就要出发了,上午教练还搞了一场欢乐信心赛,然而还是挂惨了.T3是bzoj的原题,但是当时写的 ...

  7. ThreeJS模拟人沿着路径运动-路径箭头使用纹理offset偏移

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. bootstrap Table的使用方法

    1.官网 url:http://bootstrap-table.wenzhixin.net.cn/zh-cn/documentation/ 文档包含了表格属性.列属性.事件.方法等等. 2.引入库 只 ...

  9. laravel开发之-(1)数据库链接测试

    composer安装成功后,网站建设的操作记录: 一.修改默认首页.伪静态配置文件 1.将serve.php改为index.php 2.public文件夹下的.htaccess文件复制到根目录下 二. ...

  10. sublime text 3中browsersync的使用

    1.在项目所在位置右键选择Git Bash Here 2.输入 // --files 路径是相对于运行该命令的项目(目录) browser-sync start --server --files &q ...