一.首先介绍下单字节字符集 多字节字符集

2.2字符编码方案
2.2.1 单字节编码
    (1)单字节7位字符集,可以定义128个字符,最常用的字符集为 US7ASCII
    (2)单字节8位字符集,可以定义256个字符,适合于欧洲大部分国家
    例如:WE8ISO8859P1(西欧、8位、ISO标准8859P1编码 )
2.2.2 多字节编码
    (1)变长多字节编码
     某些字符用一个字节表示,其它字符用两个或多个字符表示,变长多字节编码常用于对亚洲语言的支持,   例如日语、汉语、印地语等
    例如:AL32UTF8(其中AL代表ALL,指适用于所有语言)、zhs16cgb231280
    (2)定长多字节编码
    每一个字符都使用固定长度字节的编码方案,目前oracle唯一支持的定长多字节编码是AF16UTF16,也是仅用于国家字符集
2.2.3 unicode 编码
    Unicode 是一个涵盖了目前全世界使用的所有已知字符的单一编码方案,也就是说Unicode为每一个字符提供唯一的编码。UTF-16是unicode的16位编码方式,是一种定长多字节编码,用2个字节表示一个unicode字符,AF16UTF16是UTF-16编码字符集。
    UTF-8 是unicode的8位编码方式,是一种变长多字节编码,这种编码可以用1、2、3个字节表示一个unicode字符,AL32UTF8,UTF8、UTFE是UTF-8编码字符集

转载一个帖子,写的非常好 http://blog.itpub.net/16179598/viewspace-663045/

 

二.介绍下单字节字符集 和 多字节字符集

单字节字符集是  WE8ISO8859P1,WE8ISO8859P1是单字节8位字符集

多字节字符集是  AL32UTF8。,AL32UTF8是变长多字节编码。

ZHS16GBK

在WE8ISO8859P1字符集下,一个汉字占了1个字节,一个字符 占了1个字节;

在AL32UTF8字符集下,一个汉字占了3个字节,一个字符 占了1个字节

在ZHS16GBK字符集下, 一个汉字占了2个字节。一个字符 占了1个字节

2.1 WE8ISO8859P1字符集

SQL> select vsize('汉') from dual;

VSIZE('?')

-----------

1

SQL> select vsize('A') from dual;

VSIZE('A')

-----------

1

SQL> select lengthb('汉') from dual;

LENGTH('?')

------------

1

2.2 AL32UTF8字符集

SQL> select vsize('汉') from dual;

VSIZE('汉')

-----------

3

SQL> select vsize('A') from dual;

VSIZE('A')

-----------

1

SQL> select lengthb('汉') from dual;

LENGTH('?')

------------

3

2.3 ZHS16GBK字符集

SQL> select vsize('汉') from dual;

VSIZE('汉')

-----------

2

SQL> select vsize('A') from dual;

VSIZE('A')

-----------

1

SQL> select lengthb('汉') from dual;

LENGTH('汉')

------------

2

三. 测试结果

3.1 WE8ISO8859P1字符集-测试结果

建立下面的表:

create table t_test_var

(

v_char2 char(2),

v_char3 char(3),

v_varchar22 varchar2(2),

v_varchar23 varchar2(3),

v_varchar2 varchar(2),

v_varchar3 varchar(3),

v_nvarchar22 nvarchar2(2),

v_nvarchar23 nvarchar2(3)

);

然后分别在两个数据库中插入测试数据:

Server1:

SQL> insert into t_test_var values ('我','我','我','我','我','我','我','我');

1 row inserted

SQL> insert into t_test_var values ('我们','我们','我们','我们','我们','我们','我们','我们');

1 row inserted

SQL> insert into t_test_var values ('我们是','我们是','我们是','我们是','我们是','我们是','我们是','我们是');

insert into t_test_var values ('我们是','我们是','我们是','我们是','我们是','我们是','我们是','我们是')

ORA-12899: value too large for column
"TEST"."T_TEST_VAR"."V_CHAR2" (actual: 3,
maximum: 2)

说明WE8ISO8859P1字符集环境下char用一个字节来存储一个汉字,即:一个汉字占用一个字节

修改一下最后一条插入语句,使得char类型不越界:

SQL> insert into t_test_var values ('我们','我们是','我们是','我们是','我们是','我们是','我们是','我们是');

insert into t_test_var values ('我们','我们是','我们是','我们是','我们是','我们是','我们是','我们是')

ORA-12899: value too large for column
"TEST"."T_TEST_VAR"."V_VARCHAR22" (actual: 3,
maximum: 2)

说明WE8ISO8859P1字符集环境下varchar2类型也是一个字节存储一个汉字

再次修改:

SQL> insert into t_test_var values ('我们','我们是','我们','我们是','我们是','我们是','我们是','我们是');

insert into
t_test_var values ('我们','我们是','我们','我们是','我们是','我们是','我们是','我们是')

ORA-12899: value too large for column
"TEST"."T_TEST_VAR"."V_VARCHAR2" (actual: 3, maximum:
2)

说明WE8ISO8859P1字符集环境下varchar也是一个汉字占一个字节存储空间,

继续修改:

SQL> insert into t_test_var values ('我们','我们是','我们','我们是','我们','我们是','我们是','我们是');

insert into t_test_var values ('我们','我们是','我们','我们是','我们','我们是','我们是','我们是')

ORA-12899: value too large for
column "TEST"."T_TEST_VAR"."V_NVARCHAR22"
(actual: 3, maximum: 2)

说明WE8ISO8859P1字符集环境下nvarchar2也是一个汉字占一个字节存储空间。

这是因为在WE8ISO8859P1字符中,根本没有汉字编码。所以得出以上的实验结果。

3.2 AL32UTF8字符集-测试结果

建立下面的表:

create table t_test_var

(

v_char2 char(9),

v_char3 char(9),

v_varchar22 varchar2(9),

v_varchar23 varchar2(9),

v_varchar2 varchar(9),

v_varchar3 varchar(9),

v_nvarchar22 nvarchar2(9),

v_nvarchar23 nvarchar2(9)

);

插入测试数据:

SQL> insert into t_test_var values ('我','我','我','我','我','我','我','我');

SQL> insert into t_test_var values ('我们','我们','我们','我们','我们','我们','我们','我们');

SQL> insert into t_test_var values ('我们是','我们是','我们是','我们是','我们是','我们是','我们是','我们是');

SQL> insert into t_test_var values ('我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

insert into t_test_var values ('我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

ORA-12899: value too large for column "TEST"."T_TEST_VAR"."V_CHAR2"
(actual: 12, maximum: 9)

说明AL32UTF8字符集环境下char用三个字节来存储一个汉字,即:一个汉字占用三个字节,四个汉字需要占用12个字节

修改一下最后一条插入语句,使得char类型不越界:

SQL> insert into t_test_var values ('我们是','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

insert into
t_test_var values ('我们是','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

ORA-12899: value too large for column "TEST"."T_TEST_VAR"."V_CHAR3"
(actual: 12, maximum: 9)

说明AL32UTF8字符集环境下char用三个字节来存储一个汉字,即:一个汉字占用三个字节,四个汉字需要占用12个字节

再次修改:

SQL> insert into t_test_var values ('我们是','我们是','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

insert into
t_test_var values ('我们是','我们是','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

ORA-12899: value too large for column
"TEST"."T_TEST_VAR"."V_VARCHAR22" (actual: 12,
maximum: 9)

说明AL32UTF8字符集环境下char用三个字节来存储一个汉字,即:一个汉字占用三个字节,四个汉字需要占用12个字节

继续修改:

SQL> insert into
t_test_var values ('我们是','我们是','我们是','我们是的','我们是的','我们是的','我们是的','我们是的');

Insert into
t_test_var values ('我们是','我们是','我们是','我们是的','我们是的','我们是的','我们是的','我们是的');

ORA-12899: value too large
for column "TEST"."T_TEST_VAR"."V_NVARCHAR22"
(actual: 3, maximum: 2)

说明AL32UTF8字符集环境下char用三个字节来存储一个汉字,即:一个汉字占用三个字节,四个汉字需要占用12个字节

这是因为在AL32UTF8字符集中,根本没有汉字编码。所以得出以上的实验结果。

3.3 ZHS16GBK字符集-测试结果

建立下面的表:

create table t_test_var

(

v_char2 char(6),

v_char3 char(6),

v_varchar22 varchar2(6),

v_varchar23 varchar2(6),

v_varchar2 varchar(6),

v_varchar3 varchar(6),

v_nvarchar22 nvarchar2(6),

v_nvarchar23 nvarchar2(6)

);

插入测试数据:

SQL> insert into t_test_var values ('我','我','我','我','我','我','我','我');

SQL> insert into t_test_var values ('我们','我们','我们','我们','我们','我们','我们','我们');

SQL> insert into t_test_var values ('我们是','我们是','我们是','我们是','我们是','我们是','我们是','我们是');

SQL> insert into t_test_var values ('我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

insert into t_test_var values ('我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

ORA-12899: value too large for column "TEST"."T_TEST_VAR"."V_CHAR2"
(actual: 8, maximum: 6)

说明ZHS16GBK字符集环境下char用两个字节来存储一个汉字,即:一个汉字占用两个字节,四个汉字需要占用8个字节

修改一下最后一条插入语句,使得char类型不越界:

SQL> insert into t_test_var values ('我们是','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

insert into
t_test_var values ('我们是','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

ORA-12899: value too large for column "TEST"."T_TEST_VAR"."V_CHAR3"
(actual: 8, maximum: 6)

说明ZHS16GBK字符集环境下char用两个字节来存储一个汉字,即:一个汉字占用两个字节,四个汉字需要占用8个字节

再次修改:

SQL> insert into t_test_var values ('我们是','我们是','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

insert into
t_test_var values ('我们是','我们是','我们是的','我们是的','我们是的','我们是的','我们是的','我们是的');

ORA-12899: value too large for column
"TEST"."T_TEST_VAR"."V_VARCHAR22" (actual: 12,
maximum: 9)

说明ZHS16GBK字符集环境下VARCHAR用两个字节来存储一个汉字,即:一个汉字占用两个字节,四个汉字需要占用8个字节

继续修改:

SQL> insert into
t_test_var values ('我们是','我们是','我们是','我们是的','我们是的','我们是的','我们是的','我们是的');

Insert into t_test_var
values ('我们是','我们是','我们是','我们是的','我们是的','我们是的','我们是的','我们是的');

ORA-12899: value too large
for column "TEST"."T_TEST_VAR"."V_NVARCHAR23"
(actual: 3, maximum: 2)

说明ZHS16GBK字符集环境下NVARCHAR用两个字节来存储一个汉字,即:一个汉字占用两个字节,四个汉字需要占用8个字节

LENGTH

Syntax

length::=

Description of the
illustration length.gif

Purpose

The LENGTH functions
return the length of char. LENGTH calculates length using characters as defined
by the input character set. LENGTHB uses bytes instead of characters. LENGTHC
uses Unicode complete characters. LENGTH2 uses UCS2 code points. LENGTH4 uses
UCS4 code points.

char can be any of the
data types CHAR, VARCHAR2, NCHAR, NVARCHAR2, CLOB, or NCLOB. The exceptions are
LENGTHC, LENGTH2, and LENGTH4, which do not allow char to be a CLOB or NCLOB.
The return value is of data type NUMBER. If char has data type CHAR, then the
length includes all trailing blanks. If char is null, then this function
returns null.

Restriction on LENGTHB The LENGTHB
function is supported for single-byte LOBs only. It cannot be used with CLOB
and NCLOB data in a multibyte character set.

Examples

The following example
uses the LENGTH function using a single-byte database character set:

SELECT
LENGTH('CANDIDE') "Length in characters"

FROM DUAL;

Length in
characters

--------------------

7

The next example assumes
a double-byte database character set.

SELECT LENGTHB
('CANDIDE') "Length in bytes"

FROM DUAL;

Length in bytes

---------------

14

oracle官方文档- length篇的更多相关文章

  1. Oracle官方文档在线查看

    1.9i Oracle官方文档在线查看 http://www.oracle.com/pls/db92/homepage 2.10g Oracle官方文档线查看 http://www.oracle.co ...

  2. Oracle 官方文档地址

    官方文档地址: https://docs.oracle.com/cd/E11882_01/index.htm

  3. centos7安装oracle11g(根据oracle官方文档安装,解决图形界面安装问题)

    一.系统及安装包 操作系统:centos 7.4 oracle版本:oracle 11g r2 二.centos环境配置 安装数据库所需要的软件包 [root@localhost data]# yum ...

  4. oracle官方文档的阅读方法

    Concept 包含了 oracle 数据库里面的一些基本概念和原理, 比如 数据库逻辑结构, 物理结构, 实例结构, 优化器, 事务等. PDF 460页 Reference 包含了动态性能视图, ...

  5. 如何查看 oracle 官方文档

    Concept 包含了 oracle 数据库里面的一些基本概念和原理, 比如 数据库逻辑结构, 物理结构, 实例结构, 优化器, 事务等. PDF 460页 Reference 包含了动态性能视图, ...

  6. [置顶] 阅读Oracle官方文档指南

    还在整理中.... EXPDP/IMPDP 相关文档:Utilities 2 Data Pump Export 3 Data Pump Import SQL*Loader 相关文档:Utilities ...

  7. oracle官方文档_查看初始化參数(举例)

    原创作品,出自 "深蓝的blog" 博客.深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/46864217 记录 ...

  8. oracle官方文档12c对应关系

    ADDCI Oracle® Database Data Cartridge Developer's Guide 12c Release 1 (12.1) E15882-05 ADFNS Oracle® ...

  9. Oracle官方文档

    Oracle DBA 10g 两日速成课程 http://www.oracle.com/webfolder/technetwork/cn/tutorials/obe/db/10g/r2/2day_db ...

随机推荐

  1. android和struts2实现android文件上传

    1.开发准备如下2个工具类 package org.lxh.util; import java.io.BufferedReader; import java.io.InputStreamReader; ...

  2. RESTful风格的Web服务框架:Swagger

    Swagger与SpringMVC项目整合 为了方便的管理项目中API接口,在网上找了好多关于API接口管理的资料,感觉目前最流行的莫过于Swagger了,功能强大,UI界面漂亮,并且支持在线测试等等 ...

  3. poj 2431 Expedition 贪心

    简单的说说思路,如果一开始能够去到目的地那么当然不需要加油,否则肯定选择能够够着的油量最大的加油站加油,,不断重复这个贪心的策略即可. #include <iostream> #inclu ...

  4. Android日志框架darks-logs使用教程

    一.配置文件 在使用darks-logs之前,我们需要为它创建一个名叫logd.properties的配置文件.如果你是需要在JAVA或WEB上使用该组件,那么你可以像配置log4j一样将它放在cla ...

  5. Win8/Win7系统下用IE11浏览器调试js脚本

    作为一个web开发者,调试js脚本是工作中的一部分,但是并不是所有的浏览器都会很好的兼容js脚本的.随着win8系统的发布,ie11也慢慢进入了大家的视野,ie11的众多优点及新特性就不必多说了(全面 ...

  6. 这次GDC China 2015的总结与关卡设计教程的梳理

    去年关卡教程总结链接:听了GDC2014关于关卡设计的讲座的总结与自己的理解 24 号去了GDC china听了讲座,没有听unity没有听VR,听了一天关卡教程,和上次的关卡教程还是有区别的,这次的 ...

  7. HDOJ(HDU) 2524 矩形A + B(推导公式、)

    Problem Description 给你一个高为n ,宽为m列的网格,计算出这个网格中有多少个矩形,下图为高为2,宽为4的网格. Input 第一行输入一个t, 表示有t组数据,然后每行输入n,m ...

  8. Android学习笔记(五)Fragment简介

    Fragment是在Android 3.0 (API level 11)中引入的Activity的子模块.初衷是为了适应大屏幕的平板电脑,我们只需要使用Fragment对UI组件进行分组.模块化管理, ...

  9. octopress添加回到顶部按钮

    准备回到顶部的png图片一枚,可以随自己喜好google.分享我的 取名top.png,保存在octopress/source/images/top.png octopress/source/_inc ...

  10. Linux安装sonarQube

    安装sonarQube之前,需要先安装JDK和mysql 服务器/home/azrlnx04/下创建三个文件夹,/java ./mysql. /sonar 一:安装JDK (1)打开http://ww ...