SQL Server中char、nchar、varchar、nvarchar的区别
对于程序中的一般字符串类型的字段,SQL Server中有char、varchar、nchar、nvarchar四种类型来对应,那么这四种类型有什么区别呢,这里做一下对比。
1.定长或变长
所谓定长就是长度固定,当要保存的数据长度不够时将自动在其后面填充英文空格,使长度达到相应的长度;有var前缀的,表示是实际存储空间是动态变化的,比如varchar,nvarchar变长字符数据则不会以空格填充。
2.Unicode或非Unicode
数据库中,英文字符只需要一个字节存储就足够了,但汉字和其他众多非英文字符,则需要两个字节存储。如果英文与汉字同时存在,由于占用空间数不同,容易造成混乱,导致读取出来的字符串是乱码。Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。而前缀n就表示Unicode字符,比如nchar,nvarchar,这两种类型使用了Unicode字符集。
3.几种数据类型的存储的最大容量
char,varchar 最多8000个英文,4000个汉字
nchar,nvarchar 最多可存储4000个字符,无论英文还是汉字
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | --创建表 CREATE TABLE TempTable( id INT PRIMARY KEY , charField CHAR (10), varcharField VARCHAR (10), nvarcharField NVARCHAR(10) ) INSERT INTO TempTable VALUES (1, 'WFTH' , 'WFTH' , 'WFTH' ) INSERT INTO TempTable VALUES (2, '无风听海' , '无风听海' , '无风听海' ) INSERT INTO TempTable VALUES (3, '' , '' , '' ) INSERT INTO TempTable(id) VALUES (4) INSERT INTO TempTable VALUES (5, '1234567890' , '1234567890' , '12345' ) SELECT DATALENGTH(charField) AS charFieldLen, DATALENGTH(varcharField) AS varcharFieldLen, DATALENGTH(nvarcharField) AS nvarcharFieldLen FROM temptable WHERE id =1 SELECT DATALENGTH(charField) AS charFieldLen, DATALENGTH(varcharField) AS varcharFieldLen, DATALENGTH(nvarcharField) AS nvarcharFieldLen FROM temptable WHERE id =2 SELECT DATALENGTH(charField) AS charFieldLen, DATALENGTH(varcharField) AS varcharFieldLen, DATALENGTH(nvarcharField) AS nvarcharFieldLen FROM temptable WHERE id =3 SELECT DATALENGTH(charField) AS charFieldLen, DATALENGTH(varcharField) AS varcharFieldLen, DATALENGTH(nvarcharField) AS nvarcharFieldLen FROM temptable WHERE id =4 SELECT DATALENGTH(charField) AS charFieldLen,charField, DATALENGTH(varcharField) AS varcharFieldLen,varcharField, DATALENGTH(nvarcharField) AS nvarcharFieldLen,nvarcharField FROM temptable WHERE id =5 |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
2012-05-03 垃圾回收器算法之引用计数器法