Chinaunix首页 | 论坛 | 博客
  • 博客访问: 579312
  • 博文数量: 718
  • 博客积分: 4000
  • 博客等级: 上校
  • 技术积分: 4960
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-17 13:24
文章分类

全部博文(718)

文章存档

2011年(1)

2008年(717)

我的朋友

分类:

2008-10-17 13:35:50

      

本文章主要阐述了在不同字符集数据间导入数据的方法。

以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上测试成功



--------------------next---------------------

阅读(266) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~