zoukankan      html  css  js  c++  java
  • Sql Server char、varchar、nchar、nvarchar的区别

    (1) 定义:

    char: 固定长度,存储ANSI字符,不足的补英文半角空格。

    nchar: 固定长度,存储Unicode字符,不足的补英文半角空格

    varchar: 可变长度,存储ANSI字符,根据数据长度自动变化。

    nvarchar: 可变长度,存储Unicode字符,根据数据长度自动变化。

    nvarchar(n) :包含 n个字符的可变长度 Unicode 字符数据。n 的值必须介于 1 与 4,000 之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度可以为零。

    varchar[(n)]:长度为 n 个字节的可变长度且非 Unicode的字符数据。n 必须是一个介于 1 和 8,000之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。所输入的数据字符长度可以为零。

    VARCHAR存储变长数据,但存储效率没有CHAR高,如果一个字段可能的值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为 VARCHAR(10)是最合算的。VARCHAR类型的实际长度是它的值的实际长度+1。为什么"+1"呢?这一个字节用于保存实际使用了多大的长度。
    从空间上考虑,用varchar合适;从效率上考虑,用char合适,关键是根据实际情况找到权衡点。

    注意: ANSI主要是以单字节来存储数据,一般适合英文。而我们常用的汉字需要用两个字节来存储,所以就要使用unicode的数据类型,不然读取出来的数据可能会乱码。

    (2)区别:

    ①从存储方式上,nvarchar是按字符存储的,而 varchar是按字节存储的;

    ②从存储量上考虑, varchar比较节省空间,因为存储大小为字节的实际长度,而 nvarchar是双字节存储;

    ③在使用上,如果存储内容都是英文字符而没有汉字等其他语言符号,建议使用varchar;含有汉字的使用nvarchar,因为nvarchar是使用Unicode编码,即统一的字符编码标准,会减少乱码的出现几率;

    ④ 如果可能涉及不同语言之间的转换,建议用nvarchar。

    (2.1)char与varchar

    char(10)

    varchar(10)

    写入“abc”
    char 损耗了硬盘10字节 = “abc”长度 + 7个空字符
    varchar损耗了硬盘3字节 = “abc”长度

    var:可变长度,会根据实际存储数据的大小动态重新分配存储空间。

    不带var:固定长度,存储3个字符也是要占用10个字节的,会自动补7个空格。

    注意:如果存储的数据超过了10个字节,那么无论是固定长度还是可变长度都会报错的。

    (2.2)char与nchar

    char()不带n的数据类型,存储中文等双字节字符,占用2个字节;存储英文,数字等每个字符占用1个字节。

    nchar() 带n的,无论存储中文还是英文、数字等,每个字符都是占用两个字节。

    注意:不带n的这些数据类型,长度最常可以设置为8000,而带n的这些数据类型,长度最长可以设置为4000,实际存储空间相同,既8000字节。

    char(8000)

    varchar(8000)

    nchar(4000)

    nvarchar(4000)

    N前缀:N代表转换为Unicode格式

    insert into student(name,birtiday) values(N'科比',1995-06-01)

    (3)优缺点:

    Nvarchar优点:判断字符串的时候可以不需要考虑中英文两种字符的差别,可以避免程序中乱码的问题。

    缺点:存储英文字符会增大一倍的存储空间.但是在存储代价已经很低廉的情况下,优先考虑兼容性会给你带来更多好处的,效率没有varchar高。

    (4)为什么要用nvarchar?

    有n前缀的,n表示Unicode字符,即所有字符都占两个字节,nchar,nvarchar

    字符中,英文字符只需要一个字节存储就足够了,但汉字众多,需要两个字节存储,英文与汉字同时存在时容易造成混乱,Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。

    (5)有关var的简单介绍:

    有var前缀的,表示是实际存储空间是变长的,varchar,nvarchar

    所谓定长就是长度固定的,当输入的数据长度没有达到指定的长度时将自动以英文空格在其后面填充,使长度达到相应的长度;而变长字符数据则不会以空格填充,比较例外的是,text存储的也是可变长。

    (6)如何使用这些类型?

    如果你肯定存储的数据长度,而且不包中文的,可以选择char类型。

    如果肯定存储的数据长度,但可能包括中文,可以选择nchar类型。

    如果不确定存储的数据长度,存储只有英文、数字的最好用varchar

    如果不确定存储的数据长度,也有可能有中文,可以选择nvarchar类型,在SQL Server2005中也是比较常用的字符数据类型。

    (7)补充

    TEXT

    text存储可变长度的非Unicode数据,最大长度为2^31-1(2,147,483,647)个字符。
    NCHAR、NVARCHAR、NTEXT
    这三种从名字上看比前面三种多了个"N"。和char、varchar比较起来,nchar、nvarchar最多存储4000个字符,不论是英文还是汉字;而char、varchar最多能存储8000个英文,4000个汉字。

    可以看出使用nchar、nvarchar数据类型时不用担心输入的字符是英文还是汉字,较为方便,但在存储英文时数量上有些损失。
    所以一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar。

  • 相关阅读:
    Mysql 执行安装脚本报错Changed limits:
    Centos6.6 安装Mysql集群
    Oracle11g RAC+DG搭建
    Oracle用函数或PIVOT实现行转列
    Oracle根据列中的特殊符号进行分组
    Hadoop on Windows with Eclipse -02- Prerequisites
    Hadoop on Windows with Eclipse -01- Introduction
    Hadoop入门之WordCount运行详解
    Hadoop namenode无法启动问题解决
    jar 打包命令详解
  • 原文地址:https://www.cnblogs.com/yuan-jun/p/6705668.html
Copyright © 2011-2022 走看看