`
yr512656630
  • 浏览: 321504 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

varchar2和nvarchar2和char最大长度

阅读更多
1.CHAR的长度是固定的,而VARCHAR2的长度是可以变化的, 比如,存储字符串“abc",对于CHAR (20)

,表示你存储的字符将占20个字节(包括17个空字符),而同样的VARCHAR2 (20)则只占用3个字节的长度

,20只是最大值,当你存储的字符小于20时,按实际长度存储。

2.CHAR的效率比VARCHAR2的效率稍高。

3.目前VARCHAR是VARCHAR2的同义词。工业标准的VARCHAR类型可以存储空字符串,但是oracle不这样做

,尽管它保留以后这样做的权利。Oracle自己开发了一个数据类型VARCHAR2,这个类型不是一个标准的

VARCHAR,它将在数据库中varchar列可以存储空字符串的特性改为存储NULL值。如果你想有向后兼容的

能力,Oracle建议使用VARCHAR2而不是VARCHAR。

何时该用CHAR,何时该用varchar2?
CHAR与VARCHAR2是一对矛盾的统一体,两者是互补的关系.
VARCHAR2比CHAR节省空间,在效率上比CHAR会稍微差一些,即要想获得效率,就必须牺牲一定的空间,

这也就是我们在数据库设计上常说的‘以空间换效率’。
VARCHAR2虽然比CHAR节省空间,但是如果一个VARCHAR2列经常被修改,而且每次被修改的数据的长度不

同,这会引起‘行迁移’(Row Migration)现象,而这造成多余的I/O,是数据库设计和调整中要尽力避

免的,在这种情况下用CHAR代替VARCHAR2会更好一些。

实验说明varchar2和char最大长度

1.实验说明varchar2最大长度:

SQL> create table test3 (v2 varchar2(4001));
create table test3 (v2 varchar2(4001))
                                *
ERROR at line 1:
ORA-00910: specified length too long for its datatype

可见4001个bite太大了

SQL> create table test3 (v2 varchar2(4000));
Table created.

可见varchar2的最大长度是4000bite。

2.实验说明char最大长度:

SQL> create table test2 (v2 char(2001));
create table test2 (c char(2001))
                            *
ERROR at line 1:
ORA-00910: specified length too long for its datatype

可见4001个bite太大了

SQL> create table test1 (c char(2000));
Table created.

可见char的最大长度是2000bite。

3.NVARCHAR2(size)

可变长度的字符串,依据所选的国家字符集,其最大长度为size个字符或字节;size的最大值取决于储存每个字符所需的字节数,其上限为2000;你必须指定一个NVARCHAR2的size;

1.nvarchar中字符为中文则一般按2个字节计算,英文数字等按照一个自己计算
2.nvarchar2中所有字符均按照2个字节计算;
3.nvarchar2虽然更占空间,但是它有更好的兼容性,所有推荐使用;
分享到:
评论
1 楼 dsjt 2014-08-19  
oracle(UTF-8) 某列类型是varchar2(4000);但是 超过2000就不行:数据大小超出此类型的最大值: 2356。

相关推荐

    oracle中varchar2(byte)和varchar2(char).doc

    综上所述,`VARCHAR2(BYTE)`和`VARCHAR2(CHAR)`的主要区别在于长度单位的不同:前者按字节计数,后者按字符计数。在实际应用中,根据数据的具体特点选择合适的长度单位是非常重要的。特别是在处理包含大量非ASCII...

    浅析Oracle中char和varchar2的区别 电脑资料.docx

    首先,char 是定长的字符串类型,例如 char(10) 表示这个字段的长度是 10 个字符,如果我们存储的数据少于 10 个字符,剩下的空间将被空格填充,而 varchar2 则不同,varchar2(10) 只是表示这个字段的最大长度是 10 ...

    char,varchar以及varchar2的区别

    今天我们将深入探讨三种常见的字符串类型:`char`、`varchar`和`varchar2`,它们在不同的数据库系统中有着微妙的区别。 1. **char类型** `char`是一种固定长度的字符串类型,无论实际存储的数据是否填满指定长度,...

    oracle char,varchar,varchar2的区别和使用方法

    其中最常用的三种类型包括:`CHAR`, `VARCHAR`, 和 `VARCHAR2`。这三种类型的差异主要体现在存储方式、性能影响以及兼容性等方面。接下来将详细探讨它们之间的区别及具体的使用场景。 #### 1. CHAR - **定义**:`...

    Mysql中varchar长度设置方法

    在MySQL中,`VARCHAR`是一种用于存储可变长度字符串的数据类型,它的长度设置是非常关键的,因为它直接影响到存储空间的使用效率和数据的正确性。`VARCHAR`的长度设置方法是通过在类型名后面括号内指定最大字符数,...

    对比MySQL中int、char以及varchar的性能

    本文主要讨论了int、char和varchar这三种常见数据类型在性能上的差异。通常,这些差异在无索引和有索引的情况下的表现会有所不同。 首先,从无索引的全表扫描角度来看,测试结果显示int和bigint(即i8)在查询性能...

    char和varchar在mysql中的效率怎样.docx

    在MySQL数据库中,`CHAR`和`VARCHAR`是两种常见的字符串数据类型,它们在存储和处理数据时具有不同的效率特点。理解这两种类型的差异对于优化数据库性能至关重要。 `CHAR`是一种固定长度的数据类型,这意味着无论...

    VARCHAR与CHAR字符型数据的差异.docx

    2. 字符长度的相似性:如果字段的长度大部分时间相近,如电话号码,即使长度较长,使用CHAR可能更合适,因为长度变化不大,浪费的空间相对有限。 3. 空间效率:如果字段长度差异大,经常存储较短的字符串,VARCHAR能...

    varChar和Char之间的区别?

    `text`是用于存储长文本数据的,它的长度可变,最大长度远超`char`和`varchar`。例如,`text`的最大长度为2^31-1个字符,适合存储文章、文档等内容。 对于Unicode字符,有对应的`nchar`和`nvarchar`。`nchar`是固定...

    MYSQL中 char 和 varchar的区别

    当要存储的字符超过CHAR/VARCHAR指定的最大长度。在sql mode 没开启的时候是截断要存储的字串,只存储前30位 CHAR列中的值是定长的字符串。长度可以指定为0到255个字符(例如utf8mb4: 0-255*4个字节)之间的值当使用...

    MySQL动态修改varchar长度的方法

    在MySQL中,`VARCHAR`类型用于存储可变长度的字符串,它相较于`CHAR`类型更加节省空间,因为它只存储实际输入的数据长度。然而,在数据库设计过程中,有时可能会遇到需要动态修改`VARCHAR`字段长度的情况,这通常是...

    char和vchar2区别

    在数据库领域中,`char` 和 `varchar2` 是两种常见的字符数据类型,它们被广泛应用于各种关系型数据库管理系统(RDBMS)中,尤其是在Oracle数据库中更为常见。理解这两种数据类型的差异对于有效地设计数据库表结构、...

    浅析Oracle中char和varchar2的区别

    本文主要探讨的是两种常见字符串类型:`CHAR`和`VARCHAR2`,它们在使用上有何不同,并且会涉及一些相关的Oracle数据库功能。 首先,`CHAR`是定长字符串类型,这意味着当你声明一个`CHAR(10)`字段时,无论你存储的...

    MySQL中VARCHAR与CHAR格式数据的区别

    在MySQL数据库中,CHAR和VARCHAR是两种常见的字符串数据类型,它们在存储和处理方式上有着显著的区别,这对于数据库设计和性能优化至关重要。 首先,CHAR是一种固定长度的数据类型。这意味着无论你存储的实际数据有...

    mysql VARCHAR的最大长度到底是多少

    它在存储空间上比固定长度的CHAR类型更为高效,因为VARCHAR只存储实际输入的数据长度,而不是固定长度的列。 关于VARCHAR的最大长度,确实存在一些误解。通常认为VARCHAR的最大长度为65,535个字节,但这并不完全...

    SQLServer中char、varchar、nchar、nvarchar的区别

    - **最大长度限制**: `char`和`varchar`的最大长度为8000个字符(非Unicode),而`nchar`和`nvarchar`的最大长度为4000个字符(Unicode)。 - **Unicode支持**: Unicode类型(`nchar`、`nvarchar`)能够支持更广泛的...

    Mysql varchar大小长度问题介绍

    `,最大N值为(65535 - 1 - 2 - INT长度 - CHAR长度) / VARCHAR编码每个字符的字节数。在这个例子中,减去4是因为INT类型的c占4个字节,减去30 * 3是因为CHAR(30)占用90个字节(UTF-8编码下每个字符3字节),然后除以...

    Sqlserver中char,nchar,varchar与Nvarchar的区别分析

    在SQL Server中,字符数据类型是用来存储文本信息的,包括char、nchar、varchar和nvarchar。这四个数据类型都有各自的特点和用途,下面我们逐一详细分析它们的区别。 1. **char类型**: - char是固定长度的字符...

    MySQL中CHAR和VARCHAR类型演变和详解

    当向CHAR或VARCHAR列插入的值超过列的最大长度时,MySQL会默认截断超出部分,如果截断的是非空格字符,可能会产生警告或错误,具体取决于是否启用了严格模式。例如,如果向CHAR(4)列插入'abcdefgh',实际存储的将是'...

Global site tag (gtag.js) - Google Analytics