社区
基础和管理
帖子详情
导入数据库错误,提示无法转换字符集*(850-852)。。急
lnzyb
2003-02-27 10:54:41
在线等
...全文
301
12
打赏
收藏
导入数据库错误,提示无法转换字符集*(850-852)。。急
在线等
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用AI写文章
12 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
fxbsmile
2003-02-27
打赏
举报
回复
850到852
修改数据库
connect sys/change_on_install
update props$ set value$ = 'ZHS16CGB231280' where value$ = 'ZHS16GBK'
修改注册表
regedit
ORACLE HOME1 NLS_LANG: SIMPLIFIED CHINESE_CHINA.ZHS16CGB231280
852到850
connect sys/change_on_install
update props$ set value$ = ZHS16GBK where value$ = ZHS16CGB231280
regedit
修改注册表
ORACLE HOME1 NLS_LANG: SIMPLIFIED CHINESE_CHINA.ZHS16GBK
你可以结贴了,
lnzyb
2003-02-27
打赏
举报
回复
up
lnzyb
2003-02-27
打赏
举报
回复
不了解呀,有没有什么具体解决的办法??
我把老的数据库的database文件夹考到新的oravle中,找不到用户。为什么,不是说oracle支持文件移植吗?
CHENGTOM
2003-02-27
打赏
举报
回复
字符集转换的原因
Export、Import过程如下图所示,从这个示意图中可以看到有四处关系到字符集,而这四处字符集的不一致恰恰是导致Oracle进行字符集转换的原因。
源数据库字符集;
Export过程中用户会话字符集;
Import过程中用户会话字符集;
目标数据库字符集。
在Export和Import过程中,如果存在影响字符集转换的四因素不一致,则可能发生Oracle字符集转换,即:
在Export过程中,如果源数据库字符集与Export用户会话字符集不一致,会发生字符集转换,并在导出的二进制格式Dmp文件的头部几个字节中存储Export用户会话字符集的ID号。在这个转换过程中可能发生数据的丢失。
例1: 如果源数据库使用ZHS16GBK,而Export用户会话字符集使用US7ASCII,由于ZHS16GBK是8位字符集,而US7ASCII是7位字符集,这个转换过程中,中文字符在US7ASCII中不能够找到对等的字符,所以所有中文字符都会丢失而变成“?? ”形式,即这种转换后生成的Dmp文件已经发生了数据丢失。
例2: 如果源数据库使用ZHS16GBK,而Export用户会话字符集使用ZHS16CGB231280,但由于ZHS16GBK字符集是ZHS16CGB231280字符集的超集,这个过程中绝大部分字符都能够正确转换,只有一些超出ZHS16CGB231280字符集的字符变为“?? ”形式。如果源数据库使用ZHS16CGB231280字符集,而Export用户会话使用ZHS16GBK字符集,则转换过程能够完全转换成功。
在Import向目标数据库转换过程中,其字符集发生转换的情况正好与Export过程相反,这里不再详述。
在Export导出的Dmp文件中,含有Export用户会话字符集。在Import过程中,首先发生的是Dmp文件字符集(即Export用户会话字符集)向Import用户会话字符集的转换。如果这个转换过程不能正确完成,Import向目标数据库的导入过程也就不能完成。
进行字符集的正确转换
通常情况下,我们在使用Oracle的Export和Import过程中,并不希望发生字符的转换,但有时这种转换却是必要的。如我们在安装Oracle数据库时,选择ZHS16CGB231280字符集,由于这种字符集是一种中文小字符集,对于一些汉字不能够正确表示,这需要通过使用ZHS16GBK字符集得到解决,此时就要进行字符集的转换。
为了确保Export、Import过程中,Oracle字符集不发生转换或正确转换,建议最好在进行这个过程前,检查一下源数据库字符集与Export用户会话字符集是否一致,源数据库字符集与目标数据库字符集是否一致,目标数据库字符与Import用户会话字符集是否一致。如果能够保证这四个字符集是一致的,则在Export、Import过程中,Oracle字符集就不用发生转换。
可用以下办法检查数据库字符集:
通过InitXXXX.ora文件进行查看;
借助SQL语句查看: SELECT NAME,VALUE$ FROM SYS.PROPS$ WHERE NAME=‘NLS_CHARACTERSET’。
对于Export、Import用户会话字符集,在Windows系统中也可以通过注册表中的NLS_LANG进行查看或修改,对于Unix系统则可通过设置用户的环境变量NLS_LANG来查看或修改。
特别要注意的是,Oracle数据库字符集通常是在创建时确定,一旦存储用户数据后就不要再修改了,因为其数据都是使用该字符集进行存储的,改换其他字符集之后,原有数据就不能够正确表示了。但如果确实想进行字符集改变,则可通过以下几步来实现:
备份数据库后删除原数据(可物理备份,如使用Export,请注意确保字符集不发生转换或数据无损失);
使用Internal用户更新sys.props$表中的字符集:
Update sys.props$ set name=‘Dest.CharSet’ Where name=‘NLS_CHARACTERSET’; COMMIT;
重启数据库;
恢复数据。
下面字符集之间的转换是可行的:
字符集子集向字符集父集转换是可行的,如ZHS16CGB231280向ZHS16GBK转换;而字符集父类向字符集子集进行转换时,会损失部分数据。
只包含英文字符数据的双字节字符集也可向单字节字符集转换,如ZHS16GBK(English Only)可以向US7ASCII正确转换。
编码范围相同的单字节字符集之间通常可以进行相互转换。
请注意,这里所说的没有数据损失,是指一种字符集A转换成另一种字符集B之后,可以再从字符集B正确转换成字符集A或字符集B能够正确表示字符集A中转换过来的数据。
字符集对程序的影响
根据一个字符需要多少位字节来表示,可以把字符集分为单字节字符集和多字节字符集。其中,单字节字符集又分为7位字符集和8位字符集。单字节7位编码字符集有US7ASCⅡ,单字节8位编码字符集有符合ISO 8859-1标准规定的WE8ISO8859P1等。多字节编码又分为固定长度(长度大于或等于2)编码模式和不固定长度编码模式。多字节编码字符集中的ZHS16GBK、ZHS16CGB231280、JA16SJIS等是采用两个字节表示一个字符的字符集,又叫双字节字符集。
一个英文字母是一个字符,一个中文汉字是几个字符呢?我们知道,一个中文汉字是双字节字符,但它有几个字符与其数据库字符集有关。如果数据库字符集使用单字节US7ASCII,则一个中文汉字是二个字符;如果数据库字符集使用双字节字符集ZHS16GBK,则一个中文汉字是一个字符。有关这一点可以使用Oracle的函数Substr得到证明。
使用US7ASCⅡ字符集时:
Select substr(‘东北大学’,1,2) from dual;
语句执行结果返回‘东’。
使用ZHS16GBK字符集时:
Select substr(‘东北大学’,1,2) from dual;
语句执行结果返回‘东北’。
选择合适的数据库字符集
选择数据库字符集时应考虑以下事项:
1.数据库需要支持什么语言
在为数据库选择字符集时,常会发现几种字符集都适合你当前语言需求,如简体中文就有ZHS16GBK和ZHSCGB231280等字符集可供选择,应选择哪种?在选择字符集时,应考虑到数据库将来的系统需求。如果知道将来数据库要扩展支持不同的语言,选择一个范围较广的字符集会是一个更好的主意。
2.系统资源与应用之间的互作用性
选择的数据库字符集应保证操作系统与应用之间的无缝连接。如果选择的字符集不是操作系统有效的字符集,则系统就需要在这两者之间做字符转换。在这种字符转换过程中,就有可能发生一些字符丢失现象。从一种字符集A向另一种字符集B转换过程中,A中的字符必须在B中可以找到等价的字符,否则就会以“?”来代替。从这个意义上说,如果两种字符集编码范围是相同的,则可以相互转换。
字符集转换过程中会影响系统性能,因此,应保证客户端和服务器端有相同的字符集以避免字符集转换,也可以提高一定的系统性能。
3.系统的性能要求
不同的数据库字符集对于数据库的性能是有一定影响的。为了得到最好的数据库性能,选择的数据库字符集应避免字符转换,并且要选择对于期望的语言有最高效的编码效率。通常,单字节字符集比多字节字符集有更优的性能表现,在空间需求方面也更小些。
4.其他一些限制
在为数据库选择一个合适的字符集时,应参考Oracle对应版本的相关文档,检查Oracle对于一些字符集的限制。如Oracle 8.1.5版本中,以下字符集是不能使用的: JA16EUCFIXED、ZHS16GBKFIXED、JA16DBCSFIXED、KO16DBCSFIXED、ZHS16DBCSFIXED、JA16SJISFIXED、ZHT32TRISFIXED。
综上所述,正确理解Oracle字符集的转换过程,可以使我们避免不必要的麻烦和数据损失。合理利用Oracle字符集的转换过程,也可以帮助我们正确地从一种字符集转换到另一种字符集,以满足我们各种不同的应用需求。
lnzyb
2003-02-27
打赏
举报
回复
把原nt系统的数据倒入到2000server系统中.nt系统的注册表中的字符集是台湾的BIG5,sqlplus中的字符集是231080的字符集。2000中的字符集是ZHS16GBK。在倒入时字符集不对。我把2000系统中的字符集修改成nt的字符集时不好用。请问是否有其他办法
lnzyb
2003-02-27
打赏
举报
回复
修改后是否用重心启动计算机?式过。不成
bearpp
2003-02-27
打赏
举报
回复
set NLS_LANG AMERICAN_AMERICA.ZHS16CGB231280
lnzyb
2003-02-27
打赏
举报
回复
我式过修改注册表,但不成功
lnzyb
2003-02-27
打赏
举报
回复
直接拷贝database 文件夹是否好使????????????
CHENGTOM
2003-02-27
打赏
举报
回复
http://metalink.oracle.com/metalink/plsql/ml2_documents.showDocument?p_database_id=FOR&p_id=294416.999
看看这个吧。
CHENGTOM
2003-02-27
打赏
举报
回复
你将为此付出很大的代价。我们将从两个方面来说明问题。
首先字符集转换并非单纯的更新PROPS$表,它只是第一步。比如第二步必须是更新cols$.charset_id字段。你可以用oradebug 输出trace查看
其直接后果将使某些data dictionary信息无法访问,如表的statistics,OPTIMIZER也将无法正常工作
第二方面,直接更新此表并不转换存储内容的字符集,比如原先是zhs16gbk的,直接:
update sys.props$ set name = 'UTF8' where name = 'NLS_CHARACTERSET';
将会使汉字乱码。
在9i里面,直接Update数据库字符集,还会造成优化器的极度变态工作。
最后还是重新Create的Database。
这个同时还会导致Exp等出错
从US7ASCII到别的,可以直接ALTER DATABASE实现。
别的几乎都不可以。
只有从严格的子集到父集,才能这样实现。
CHENGTOM
2003-02-27
打赏
举报
回复
哎,又一个update props$的,这样会害死人的
sybase
字符集
转换
sybase
数据库
字符集
转换
,如将默认安装的cp
850
字符
转换
为支持中文的cp936
java基础教程----精华版
java基础教程----精华版,不得不下载的资源
php版mysql大
数据库
备份和恢复工具
php版mysql大
数据库
备份和恢复工具,这是亮仔修改的无乱码版 在原faisunSQL 4.0的基础上,针对数据备份过程中出现乱码的问题,做了优化. 增强的功能: 1.自动识别
数据库
版本,对于MySQL 4.1以上,备份数据时
提示
选择
字符集
. 2.
导入
数据时,
提示
原
数据库
编码,并自动识别. 3.增加
导入
目标
数据库
字符集
选项. 4.支持GBK、BIG5、UTF8之间的编码
转换
(见特别说明4). 特别说明: 1.乱码问题一般仅出现在MySQL 4.1/MySQL 5 版本以后,如果你的
数据库
低于这个版本,基本可以不用考虑这个问题. 2.确保原始数据的完整是至关重要的.就算导出时出现乱码,但只要原始数据完整,总有解决的办法.所以,导出时
数据库
字符集
的选择必须正确,保证导出数据无乱码.一般为GBK,UTF8或Latin1.导出后,可以用文本编辑器先查看一下,看是否出现问号(?)等乱码. 3.导出和
导入
数据编码要保持一致(见特别说明4). 4.虽然程序目前支持GBK、BIG5、UTF8之间的编码
转换
,但这种
转换
不是安全的.首先你的目标
导入
服务器要支持iconv,即在
导入
时如果"编码
转换
功能"
提示
为支持,则可以使用此功能.反之则不可以.其次,
转换
时的数据必须是"干净"的.即GBK、BIG5、UTF8不能混合.如果你想将原来备份出的GBK数据
导入
到编码为UTF8
数据库
,则你的GBK数据中仅能含有GBK或GB2312的简体中文字符.不可以出现BIG5等繁体字符,否则
转换
将失败.基本上,一般的博客/论坛数据都不能保证这种纯净性,谁也不能保证你的文章中不会混合使用简体和繁体文字,所以这种跨
字符集
的
导入
导出数据难度很大.绝对不要轻易尝试这种游戏.目前的主流论坛如Discuz、PHPWind等都提供支持GBK、BIG5和UTF8的不同程序.你在最初安装时,一定先想好自己需要那种字符的程序,一旦选定,以后不是迫不得已,不要更改.以上仅针对 5.鉴于上面特别说明4,如果你是从MySQL 4.0.X/MySQL 3的老数据版本
导入
到MySQL 4.1/MySQL 5的高
数据库
版本,
导入
时请选择GBK编码.如果是UTF8编码的数据,如我的博客(http://www.zhouliang.name)采用WordPress程序,默认使用UTF8编码,则只能在MySQL 4.1/MySQL 5以上的
数据库
中
导入
导出,因为低版本的MySQL不支持UTF8. 6.以上说明仅针对本程序而言,在编码
转换
方面,不排除通过其他手段实现的可能性. 程序使用中出现任何问题(编码
转换
方面),欢迎与我联络: 我的E-Mail: php@zhouliang.name 本程序讨论主页:http://www.zhouliang.name/archives/198.htm 我的博客:http://www.zhouliang.name 此程序只是针对"乱码"问题做了改进,faisunSQL 4.0其他方面的故有功能效率与本增强版无关,如有问题请联系原作者.
文本文件编码
转换
工具 gbk utf8 gb2312
写此贴为记录自己的学习历程,供后来者以观. 原因,我决定学习PHP+MYSQL之后选择了用整合包的环境(因为我懒) 经过历时一个星期的比较 揣摩 测试之后选择了 VertrigoServ 可是它美中不足的是mysql里中文显示"????????".最后几经周折总算解决了. 方法如下: 1)在phpmyadmin 中建库的时候一切默认 2)建表时候一切默认;至于
导入
*.SQL没试应该是不用动什么 3)在 php 文件头部加入 "说明此文件编码为utf8" 4)在 mysql_select_db("表名",$id); 后面加入一行 mysql_query("set names utf8;"); 5)*.php 文件在存盘的时候也以 "utf-8"编码存盘. 如此一来整站编码就都是国际能用的utf8编码了.通用性现在做到最好了. 问题也是有的,在此环境下涉及到
数据库
运行的文件都必须是 utf8编码.这样一来就出现了不兼容,因为在国内大家都是以GBK gb2312编的码 包括 17PHP.com 网站里的学习源码文件(我用的是77例中的) 和很多插件 论坛代码... ...Discuz!也是的 解决起来很简单,把它们的编码都改成 utf8 好了. 批量文件转码工具
解决imp
导入
dmp文件报:IMP-00038:
无法
转换
为环境
字符集
句柄IMP-00000: 未成功终止
导入
当我们在oracle
数据库
中
导入
数据库
时 常常使用imp.exe
导入
。如果报用cmd impdp
导入
时imp
导入
dmp文件报:IMP-00038:
无法
转换
为环境
字符集
句柄IMP-00000: 未成功终止
导入
。尝试在cmd使用impdp
导入
注意:必须创建directory实例写入dmp文件所在目录 然后在cmd语句中调用实例 不然会遇到ORA-39002、ORA-39070
错误
创建...
基础和管理
17,382
社区成员
95,118
社区内容
发帖
与我相关
我的任务
基础和管理
Oracle 基础和管理
复制链接
扫一扫
分享
社区描述
Oracle 基础和管理
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章