在不同字符集的数据库之间导入数据的方法
2007-04-29 08:59
369 查看
以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上测试成功。
假设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上测试成功。
相关文章推荐
- SQL不同数据库之间数据导入方法
- Oracle817 版本 不同字符集之间的数据库导入
- ORACLE同一个数据库下不同表结构之间的数据导入
- 不同数据库数据导入方法
- Oracle 字符集不同数据导入的方法(实战经验)
- 不同数据库之间复制表的数据的方法
- 主流数据库之间对SQL:2003标准的不同实现方法比较(第四部分 查询结果集中间n行数据)
- 不同版本的SQL Server之间数据导出导入的方法及性能比较
- SQL Server 跨服务器 不同数据库之间复制表的数据的方法:
- 主流数据库之间对SQL:2003标准的不同实现方法比较(第六部分 基础数据类型之BOOLEAN)
- 不同数据库之间复制表的数据的方法
- [转]不同版本的SQL Server之间数据导出导入的方法及性能比较
- 使用OPENDATASOURCE和OPENROWSET在不同类型的数据库之间导入导出数据
- 利用SQL脚本导入数据到不同数据库避免重复的3种方法
- 不同数据库之间复制表的数据的方法
- Oracle817 版本 不同字符集之间的数据库导入
- 不同版本的SQL Server之间数据导出导入的方法及性能比较
- 不同版本的SQL Server之间数据导出导入的方法及性能比较
- oracle 10g 字符集不同的库之间的数据导入导出问题
- 不同数据库之间复制表的数据的方法