问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

字符集编码问题

发布网友 发布时间:2022-04-23 06:06

我来回答

2个回答

懂视网 时间:2022-05-05 13:55

Oracle全球支持(即GlobalizationSupport)允许我们使用本地语言和格式来存储和检索数据。通过全球支持,Oracle可以支持多种语言及字符集,得以展示数据库的强大魅力。 由于不同语言及字符集的共同存储存在设置上具有一定的复杂性,字符集一度成为普遍困扰大家

Oracle全球支持(即Globalization Support)允许我们使用本地语言和格式来存储和检索数据。通过全球支持,Oracle可以支持多种语言及字符集,得以展示的强大魅力。
由于不同语言及字符集的共同存储存在设置上具有一定的复杂性,字符集一度成为普遍困扰大家的一个主要问题。
本文试图就一些常见问题进行探讨,希望可以把一些实际经验共享给大家!
1. 字符集的基本知识
如果从头说起,字符集最早的编码方案来自于与ASCII.
这也是我们最常见的编码方式。该方案起源于1960年代初期,最初是美国国会图书馆制定用来作为美国图书馆界书目交换的共同标准,最后完善成为美国的国家标准ASCII(American Standard Codefor Information Interchange),之后进一步演变成世界性的计算机字符编码标准ISO646(其全名为7-bit coded character set for information interchange)。成为计算机编码方案的基础。
Oracle数据库最早支持的编码方案也就是US7ASCII.
但是我们知道,英文字符一般是以一个字节来存储的,7位的编码方案最多只能代表128个字符;经过扩展的8位的编码方案也只能代表256个字符,这远远不能满足计算机发展的需要,对于亚洲国家复杂的字符存储需要更多的码位,于是各种编码方案随之而生。
为了容纳全世界各种语言的所有字符和符号,解决不同编码之间的兼容和转换问题,1991年元月,10多家公司共同出资,组建Unicode协会,随后Unicode编码产生了。
Unicode协会的口号是: 给每个字符提供了一个唯一的数字,不论是什么平台,不论是什么程序,不论什么语言。
最初Unicode编码使用2-Byte(16bit)来进行编码,但是最多只能容纳65536个字符,仍然不够使用,后来进行了扩充,也就是Unicode3.1标准,增加了额外的补充字符定义,现在Unicode4.0标准已经发布,具体可以参考Unicode官方站点:
www.unicode.org

Unicode编码方案主要有三个实施标准:
UTF-8
USC-2
UTF-16
Oracle从7.2开始支持UTF-8编码,提供Unicode编码支持。
按照各种标准的含义,Oracle推荐,如果你的数据库需要存放不同语言的不同符号和字符,建议使用Unicode编码方案。诚然,Unicode方案可以表示更多的字符,但是由于多位的存储,需要额外的存储空间和网络传输,所以选择最适合的数据库字符集仍然需要慎重考虑。

2. 数据库的字符集
字符集在创建数据库时指定,在创建后通常不能更改,所以在创建数据库时能否选择一个正确的字符集就显得尤为重要。
在创建数据库时,我们可以指定字符集(CHARACTER SET)和国家字符集(NATIONAL CHARACTER SET)。
字符集用来存储:
CHAR, VARCHAR2, CLOB, LONG等类型数据
用来标示诸如表名、列名以及PL/SQL变量等
SQL和PL/SQL程序单元等
国家字符集用以存储:
NCHAR, NVARCHAR2, NCLOB等类型数据
这些设置在数据库创建时指定,我们可以看一下数据库的创建脚本:

connect SYS/change_on_install as SYSDBA
set echo on
spool E:oracleora92assistantsdbcalogsCreateDB.log
startup nomount pfile="E:oracleadmineyglescriptsinit.ora";
CREATE DATABASE eygle
MAXINSTANCES 1
MAXLOGHISTORY 1
MAXLOGFILES 5
MAXLOGMEMBERS 3
MAXDATAFILES 100
DATAFILE ’E:oracleoradataeyglesystem01.dbf’ SIZE 250M REUSE AUTOEXTEND ON NEXT 10240K MAXSIZE UNLIMITED
EXTENT MANAGEMENT LOCAL
DEFAULT TEMPORARY TABLESPACE TEMP TEMPFILE ’E:oracleoradataeygle emp01.dbf’ SIZE 40M REUSE AUTOEXTEND
ON NEXT 640K MAXSIZE UNLIMITED
UNDO TABLESPACE "UNDOTBS1" DATAFILE ’E:oracleoradataeygleundotbs01.dbf’ SIZE 50M REUSE AUTOEXTEND
ON NEXT 5120K MAXSIZE UNLIMITED
CHARACTER SET ZHS16GBK
NATIONAL CHARACTER SET AL16UTF16
LOGFILE GROUP 1 (’E:oracleoradataeygle edo01.log’) SIZE 10M,
GROUP 2 (’E:oracleoradataeygle edo02.log’) SIZE 10M,
GROUP 3 (’E:oracleoradataeygle edo03.log’) SIZE 10M;
spool off
exit;

以上用粗体显示的就是对我们至关重要的字符集设置。

热心网友 时间:2022-05-05 11:03

你自己在电脑上新建一个文本文件,里面写一个汉字 张。

ANSI 编码,文件大小2字节,UTF-8编码,文件大小6字节
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
北京注册成立一个公司需要多少钱 北京公司都是什么 手机导航地图语音怎么下载 如何分别真金和仿金首饰 怎样区分真金和仿金首饰呢 小学生新年晚会主持人的串词!!(不要太多)急 大大后天就需要了!!!_百度... 周年晚会策划公司 奥格瑞玛传送门大厅在哪 奥格瑞玛传送门大厅怎么走 锻炼颈椎的几个动作 水多久能结冰 冰能在多长时间内形成 c语言中文编码的问题 Java编码问题。 URLDecode编码问题 UTF-8的编码和解码问题 网站编码问题,怎么解释? 字符编码问题 Javabean编码问题 编码问题 拼多多上的手机是正品吗?那么便宜 拼多多买苹果手机靠谱吗百亿补贴的? 在拼多多上买手机靠谱吗? 拼多多卖的手机是正品? 拼多多上买的二手手机信得过吗? 拼多多上买手机是正品吗? 在拼多多上买手机靠谱么? 如何将在Windows系统上写好的项目部署到Lin 拼多多手机便宜那么多是正品吗 抖音小店随心推充值100投放 用不了钱会退回来吗 小店随心推投可以提前做吗 有关星座的问题 关于UTF-8编码问题 编码问题(用free pascal) 我用word打开文档,发现没有适合的文本编码,请问如何解决编码问题? 请教关于编码解码问题,难 2021年上海宽带的价格? 信息编码的过程是什么? 家里要装宽带,什么宽带好啊? 编码问题(翻译乱码) 二进制编码问题 宁波华数宽带套餐价格表2021 编码方式是什么? 2021年联通宽带套餐价格表? 电信单宽带价格表2021? JAVA字符编码问题 青少年需要那些营养,吃什么补充? 青少年饮食,青少年饮食禁忌,青少年吃什么好 电信家庭宽带套餐价格表2021年的有没有? 2021宽带办理哪个最便宜 青少年应该多吃点什么? 三个工作日是多久呢?