Sql Server 中char、nchar、varchar、nvarchar这几种数据类型的区别

一、从外形上看区别

char、nchar、varchar、nvarchar这四种数据类型都是用来存储字符串数据的,从外形上来看,我们能够发现他们四个之间是有所联系的。

“char”在这四种数据类型中属于最基础的,每个类型都含有“char”这个单词,“nchar”比“char”多了“n”,“varchar”比“char”多了“var”,“nvarchar”比“char”多了“n”和“var”。

这时的我们就要思考,“n”和“var”是不是有某种特殊的含义限制了字符串?答案是肯定的。

“n”:含“n”表示能够存储中文,可以存4000字节

       不含“n”表示能够存储英文,可以存8000字节

“var”:含“var”表示字符串长度可变

          不含“var”表示字符串长度不可变

由此我们能够看出这四种数据类型的基本区别:

char:能够存储英文,可以存8000字节,长度不可变

nchar:能够存储中文,可以存4000字节,长度不可变

varchar:能够存储英文,可以存8000字节,长度可变

nvarchar:能够存储中文,可以存4000字节,长度可变

二、从含义上看区别

这四种数据类型中有“n”前缀的,表示Unicode字符,即所有字符都占两个字节——nchar、nvarchar

这四种数据类型中没有“n”前缀的,表示ANSI字符,所有字符都占一个字节——char、varchar

由此能看出,在存储方面varchar比nvarchar更节省空间,因为varchar存入多少字符就占用多少空间,而nvarchar则要×2

三、不同的使用场景

列中的数据值大小接近一致,使用char

列中所有数据项的大小接近一致,使用nchar

列中的数据值大小显著不同,使用varchar

列中的数据项的大小差异很大,使用nvarchar

 

含有中文字符的使用nchar和nvarchar

含有纯英文和数字的使用char和varchar

  • 22
    点赞
  • 108
    收藏
    觉得还不错? 一键收藏
  • 22
    评论
Oracle、MySQLSQL Server是三种常见的关系型数据库管理系统(RDBMS),它们在数据类型方面存在一些区别。以下是它们主要的数据类型及其区别: 1. 字符串类型: - Oracle:包括CHARVARCHAR2、NCHAR、NVARCHAR2等。 - MySQL:包括CHARVARCHAR、TINYTEXT、TEXT、LONGTEXT等。 - SQL Server:包括CHARVARCHAR、NCHAR、NVARCHAR、TEXT等。 2. 数值类型: - Oracle:包括NUMBER、INTEGER、FLOAT、DOUBLE PRECISION等。 - MySQL:包括INT、BIGINT、FLOAT、DOUBLE等。 - SQL Server:包括INT、BIGINT、FLOAT、REAL等。 3. 日期和时间类型: - Oracle:包括DATE、TIMESTAMP、INTERVAL等。 - MySQL:包括DATE、TIME、DATETIME等。 - SQL Server:包括DATE、TIME、DATETIME等。 4. 二进制类型: - Oracle:包括BLOB、RAW等。 - MySQL:包括BLOB、BINARY等。 - SQL Server:包括BLOB、BINARY等。 5. 布尔类型: - Oracle:不支持原生的布尔类型,可以使用NUMBER(1)或CHAR(1)来表示。 - MySQL:支持BOOL或BOOLEAN类型。 - SQL Server:不支持原生的布尔类型,可以使用BIT来表示。 6. 其他特殊类型: - Oracle:包括CLOB(大文本)、BFILE(二进制文件)等。 - MySQL:包括ENUM、SET等。 - SQL Server:包括XML、CURSOR等。 需要注意的是,尽管这些数据库有一些相同的数据类型,但在具体实现和功能上可能存在一些差异。此外,每个数据库还可能支持一些特定的扩展类型或自定义类型。 在选择数据库和设计表结构时,应该根据具体的应用需求和数据库的特性来选择合适的数据类型

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值