一、各自的定义:编码
► nvarchar(n) : 包含 n 个字符的可变长度 Unicode 字符数据。n 的值必须介于 1 与 4,000 之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度能够为零。spa
► varchar[(n)]: 长度为 n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。所输入的数据字符长度能够为零。code
varchar(max)最大2gb字符 使用C#中的DbType.varchar 针对max DbType.varchar,-1字符编码
二、区别:table
► 从存储量上考虑, varchar比较节省空间,由于存储大小为字节的实际长度,而 nvarchar是双字节存储;乱码
► 在使用上,若是存储内容都是英文字符而没有汉字等其余语言符号,建议使用varchar;含有汉字的使用nvarchar,由于nvarchar是使用Unicode编码,即统一的字符编码标准,会减小乱码的出现概率;select
►若是你作的项目可能涉及不一样语言之间的转换,建议用nvarchar。数据类型
这点要注意:varchar 适合与存储英文和数字; nvarchr通常用于存储中文或其余语言的输入,由于 这样,能够防止到其余语言平台上出现乱码的问题。数据
举个例子: create table a (name1 varchar(8)) insert a select '张红a' --- 存储长度为5个字节 insert a select '王一南' ----存储长度为6个字节项目
---意思是varchar变长字符数据类型与存储数据的实际长度是一致的
nvarchar(n):可变长度 Unicode 数据,其最大长度为 4,000 字符。 字节的存储大小是所输入字符个数的两倍, 就是说它是双字节来存储数据的。 若是存储数据若是存在单字节时,它也是以双字节来占用存储空间的。
举个例子: create table aa (name1 nvarchar(8)) insert aa select '张红a' --- 存储长度为6个字节
nvarchar (10) 里面的 10 是 10个 国际化字符 的长度, 也就是 能够存 10个 汉字varchar(10)里面的 10 , 至关于 10个 字节, 能够存 10个 字母或者数字。