oracle导入导出字符问题2

上一篇 / 下一篇  2009-08-05 16:28:32 / 个人分类:oracle安装(11g)

3、查询Oracle client端的字符集:

  这个比较简单。在Windows平台下,就是注册表里面相应OracleHome的NLS_LANG.还可以在Dos窗口里面自己设置,比如:

set nls_lang=AMERICAN_AMERICA.ZHS16GBK
  这样就只影响这个窗口里面的环境变量。 在Unix平台下,就是环境变量NLS_LANG.
$echo $NLS_LANG
AMERICAN_AMERICA.ZHS16GBK
  如果检查的结果发现Server端与Client端字符集不一致,请统一修改为同Server端相同的字符集。
上文说过,oracle的字符集有互相的包容关系。
  如us7ascii就是zhs16gbk的子集,从us7ascii到zhs16gbk不会有数据解释上的问题,不会有数据丢失。在所有的字符集中utf8应该是最大,因为它基于unicode,双字节保存字符(也因此在存储空间上占用更多)。
  一旦数据库创建后,数据库的字符集理论上讲是不能改变的。因此,在设计和安装之初考虑使用哪一种字符集十分重要。根据Oracle的官方说明,字符集的转换是从子集到超集受支持,反之不行。如果两种字符集之间根本没有子集和超集的关系,那么字符集的转换是不受oracle支持的。对数据库server而言,错误的修改字符集将会导致很多不可测的后果,可能会严重影响数据库的正常运行,所以在修改之前一定要确认两种字符集是否存在子集和超集的关系。一般来说,除非万不得已,我们不建议修改oracle数据库server端的字符集。特别说明,我们最常用的两种字符集ZHS16GBK和ZHS16CGB231280之间不存在子集和超集关系,因此理论上讲这两种字符集之间的相互转换不受支持。
cmd-->d:
imptvms2/tvms2@tvms_10.168.66.251fromuser=tvms1 touser=tvms2 file=d:\dxd192sp04_wsl.dmp  log=import.log

exptvms1/tvms1@tvms_10.168.66.251file=d:\tvms.dmp  buffer=10240000


TAG:

 

评分:0

我来说两句

Open Toolbar