本着低碳的原则将几个变量声明为nchar,结果发现尾巴上每次都多一大串空格,C#中不得不多次Trim劳心费神易出错。上网一查原来四种字符串看似相近其实讲究很多,其中以本帖最为全面,特此转发。

原帖:http://zhidao.baidu.com/question/59109925.html

原帖很长排版有点散(从里到外都很欠“Trim”一下),看下面的整理吧:

总结:1、varchar:可变长度的非Unicode   数据,最长为8,000个字符。   2、nvarchar:可变长度Unicode 数据,其最大长度为4,000字符。   3、char:固定长度的非Unicode字符数据,最大长度为 8,000 个字符。 4、nchar:固定长度的 Unicode 数据,最大长度为 4,000 个字符。 5、char和varchar都是字符串类型的,用Unicode编码的字符串,结果是字符的整数值

nchar(n)

包含n个字符的固定长度Unicode字符数据。n的值必须介于1与4,000之间。存储大小为n字节的两倍。

nchar在SQL-92中的同义词为national char和national character。

nvarchar(n)

包含n个字符的可变长度Unicode字符数据。

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

nvarchar 在 SQL-92 中的同义词为 national char varying 和 national character varying。

注释 如果没有在数据定义或变量声明语句中指定 n,则默认长度为 1。如果没有使用 CAST 函数指定 n,则默认长度为 30。

如何使用nchar(n)和nvarchar(n)

如果希望列中所有数据项的大小接近一致,则使用 nchar。如果希望列中数据项的大小差异很大,则使用 nvarchar。

使用 nchar 或 nvarchar 的对象被赋予数据库的默认排序规则,除非使用 COLLATE 子句赋予特定的排序规则。

SET ANSI_PADDING OFF 不适用于 nchar 或 nvarchar。SET ANSI_PADDING ON 永远适用于 nchar 和 nvarchar。 二、char 和 varchar 固定长度 (char) 或可变长度 (varchar) 字符数据类型。

char[(n)]

长度为 n 个字节的固定长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为 n 个字节。

char 在 SQL-92 中的同义词为 character。

varchar[(n)]

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

所输入的数据字符长度可以为零。varchar 在 SQL-92 中的同义词为 char varying 或 character varying。

注释 如果没有在数据定义或变量声明语句中指定 n,则默认长度为 1。如果没有使用 CAST 函数指定 n,则默认长度为 30。

将为使用 char 或 varchar 的对象被指派数据库的默认排序规则,除非用 COLLATE 子句另外指派了特定的排序规则。该排序规则控制用于存储字符数据的代码页。

支持多语言的站点应考虑使用 Unicode nchar 或 nvarchar 数据类型以尽量减少字符转换问题。

如何使用 char 或 varchar

如果希望列中的数据值大小接近一致,请使用 char。 如果希望列中的数据值大小显著不同,请使用 varchar。 如果执行 CREATE TABLE 或 ALTER TABLE 时 SET ANSI_PADDING 为 OFF,则一个定义为 NULL 的 char 列将被作为 varchar 处理。

当排序规则代码页使用双字节字符时,存储大小仍然为 n 个字节。根据字符串的不同,n 个字节的存储大小可能小于 n 个字符。


理解了这些,就理解了为何SQL Server自动给字符串末尾加空格,因为他们被声明为char或nchar了。

注意即使修改成var类型,原来的空格也不会自动消失,需要手工删除。

点击下载免费的敏捷开发教材:《火星人敏捷开发手册》

转载于:https://www.cnblogs.com/JPAORM/archive/2011/04/04/2510518.html

char varchar nchar nvarchar 四者的区别是什么(为何SQL Server自动给字符串末尾加空格)...相关推荐

  1. 数据库中char varchar nchar nvarchar的区别

    数据库中char varchar nchar nvarchar的区别 我们在进行数据库的设计的时候,很多情况下表中的字段都是用的是字符串类型的数据,其中就有四种选择char varchar nchar ...

  2. SQL中char varchar nchar nvarchar ntext区别和使用(资料汇总)

    SQL中char varchar nchar nvarchar ntext区别和使用(资料汇总) 2008年10月14日 星期二 23:57 一.SQL中char varchar nchar nvar ...

  3. char varchar nchar nvarchar区别

    char varchar nchar nvarchar区别 char与varchar的区别 (1) char的长度是不可变的,而varchar的长度是可变的.(也就是说,定义一个char[4]和var ...

  4. SqlServer中char,varchar,nchar,nvarchar的区别

    在数据库中建表时,总是习惯的将一些字段定义为nvarchar,但关于它和nchar的区别,却没有细究过,今天上网仔细了解一下做个总结: 1.n代表的是Unicode字符,可以解决多语言字符集之间的转换 ...

  5. oracle中varchar 和 nvarchar2的区别,Oracle中char,varchar,varchar2,nvarchar,nvarchar2的区别

    一.概述 1.char char的长度是固定的,比如说,你定义了char(20),即使你你插入abc,不足二十个字节,数据库也会在abc后面自动加上17个空格,以补足二十个字节: char是区分中英文 ...

  6. SQL中char\varchar\text与nchar\nvarchar\ntext的区别

    SQL中char\varchar\text与nchar\nvarchar\ntext的区别 定义 特点 定义 char char(n)是长度不可变的,用于表示非Unicode字符数据.n代表该数据类型 ...

  7. SQL Server中的char,nchar,varchar和nvarchar有什么区别?

    nvarchar是什么意思? SQL Server中的char , nchar , varchar和nvarchar什么区别? #1楼 char :固定长度的字符数据,最大长度为8000个字符. nc ...

  8. sql中NVARCHAR(MAX) 性能和占空间分析 varchar(n),nvarchar(n) 长度性能及所占空间分析

    sql中NVARCHAR(MAX) 性能和占空间分析 varchar(n),nvarchar(n) 长度性能及所占空间分析 观此文描述较为全面,故此转载.原地址: sql中NVARCHAR(MAX) ...

  9. SQL Server从入门到精通(四)

    今天阿猪带领大家正式进入第四步的学习 往期精选 SQL Server从入门到精通(一) SQL Server从入门到精通(二) SQL Server从入门到精通(二)精讲 SQL Server从入门到 ...

最新文章

  1. mysql 虚表_mysql虚拟表
  2. windbg内存断点学习总结
  3. Python常见问题(5):Python扩展与嵌入 Extending/Embedding FAQ
  4. 我是如何学习写一个操作系统(四):操作系统之系统调用
  5. filter过滤器_web容器的过滤器Filter和拦截器Inteceptor的区别
  6. 一文了解 Kubernetes 中的服务发现
  7. Java学习系列(十七)Java面向对象之开发聊天工具
  8. 爬虫、请求库requests
  9. ejb 2.1 jboss_带有Eclipse IDE,EJB Project和JBoss 6.0 AS的JMS 1.1生产者和使用者示例
  10. android 添加注释,向Android Saripaar添加自定义注释
  11. 自定义字体需要css的,CSS 自定义字体
  12. 微信小程序:2022虎年全新头像框制作
  13. 一文带你由浅入深Netty异步非阻塞世界(持续更新~~~)
  14. 深度学习_深度学习基础知识_二分类、单标签多分类、多标签多分类、多任务的含义
  15. 去除桌面图标文字阴影的4种方法
  16. 创业团队产品如何战胜大公司的抄袭 腾讯抄你肿么办?
  17. 谈钱增进感情-人生定位
  18. 达人篇:6.3)试验设计DOE,Design of Experiments
  19. php微信商城和微信小程序源码【CRMEB】
  20. 薪酬本地化:Facebook根据居住地发工资会怎样改变劳动力市场?

热门文章

  1. HDU(2255),KM算法,最大权匹配
  2. Freescale MC9S08AW60汇编学习笔记(三)
  3. 让人少奋斗十年的工作经验
  4. Java 实现计时器
  5. 集团公司(嵌入ETL工具)财务报表系统解决方案
  6. 小白使用word小技巧-持续更新(以论文服务为主)
  7. 计算机联锁与全电子执行单元,计算机联锁全电子执行单元
  8. 计算机与数学专业的就业前景,2019数学与应用数学专业就业前景和就业方向分析...
  9. lua按钮unity_在Unity中使用Lua脚本
  10. adobe audition cs6 能打开mpcm文件吗?_单根32G内存靠谱吗?阿斯加特 W2 32G DDR4 2666内存测试...