当前位置: 首页 > 图文教程 > 数据库 > Oracle > 在不同字符集的数据库之间导入数据的方法

Oracle
Oracle Jdbc的一些限制(10.2.0.1)
使用Instr()与decode()进行多条件组合查询
修改ORACLE的DATAFILE文件名
Oracle中向视图中插入数据
oracle中实现自动增长列
oracle同时向多表插入数据
建立与Oracle服务器连接的两种连接模式
oracle中的connect by 在sql server中实现
Oracle巧取指定记录与巧用外关联查询
如何杀死oracle死锁进程
Oracle数据直接导出到文本文件的方法
在ORACLE中实现SELECT TOP N的方法
教你用Oracle解析函数快速检查序列间隙
教你在Oracle中启动脚本跟踪存储过程
Oracle Peeking绑定变量的控制
在Oracle实例间移动SQL调整工具集
使用DBMS_METADATA包获得对象DDL
使用Oracle 10gMERGE语句更新数据行
在不同字符集的数据库之间导入数据的方法
介绍Oracle数据库去除别名的方法

Oracle 中的 在不同字符集的数据库之间导入数据的方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-31   浏览: 117 ::
收藏到网摘: n/a

    以US7ASCII的库中导出的数据导入到字符集为ZHS16GBK的库为例子:

  假设US7ASCII的库是A机,字符集为ZHS16GBK的库为B机

  1.确定你A机上的oracle用户的.profile文件中的NLS_LANG是US7ASCII,正常的导出所有数据。

  2.然后传到B机上,bin模式,然后在B机上设定好oracle用户的设定环境变量NLS_LANG=AMERICAN_AMERICA.US7ASCII

  以sys用户执行update props$ set values$='US7ASCII'

  where name='NLS_CHARACSET';

  3.正常的导入数据至ZHS16GBK的数据库中去,重新启动数据库,此时查看原来导入的数据应该已经中文了。

  4.把环境变量改回来,NLS_LANG=AMERCIAN_AMERICA.ZHS16GBK

  以sys用户登陆ZHS16GBK的数据库然后执行一下语句:

  update props$ set values$='ZHS16GBK'

  where name='NLS_CHARACSET';

  重新启动数据库让其修改生效即可。

  如果不放心,可以把当前ZHS16GBK数据库中的数据正常exp出来,然后重新建库后正常导入。

  以上过程我在oracle9.2.0和9.0.1,8.1.7上测试成功。