文档章节

SQL Server中nvarchar和varchar的区别

A
 Apirl
发布于 2018/05/29 14:32
字数 806
阅读 44
收藏 0

1、varchar(n)

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

2、nvarchar(n)

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

3、两种数据类型的区别

      首先,varchar和nvarchar都能存储汉字,区别在于:一个汉字占varchar(2),只占nvarchar(1),而字母只占varchar(1),那么在数据库字段求长度的时候,用varchar就不一定知道它确切有几个字符,如果用nvarchar,汉字也是nvarchar(1),字母也是nvarchar(1),那么很容易知道字段的长度了。

  其次,varchar的检索快于nvarchar,varchar在SQL Server中是采用单字节来存储数据的,nvarchar是使用Unicode来存储数据的,中文字符存储到SQL Server中会保存为两个字节(一般采用Unicode编码),英文字符保存到数据库中,如果字段的类型为varchar,则只会占用一个字节,而如果字段的类型为nvarchar,则会占用两个字节。正常情况下,我们使用varchar也可以存储中文字符,但是如果遇到操作系统是英文操作系统并且对中文字体的支持不全面时,在SQL Server存储中文字符为varchar就会出现乱码(显示为??),而且正常情况下,主机都会支持中文,所以如果使用varchar来存储数据,在开发阶段是发现不了问题的,多数情况下,在布署的时候也不会有问题,但是,如果布署的主机是英文操作系统,并且不支持中文,那问题就出来了,所有的varchar字段在存储中文的时候都会变成乱码(显示为??),而且一般情况下你不会知道这是因为你采用了错误的数据类型造成的,你会试着去装中文字体,试着去设置操作系统的语言环境,这些都不能解决问题,唯一能解决问题的方法是把数据库字段的类型改为nvarchar(或者nchar),对项目管理比较熟悉的朋友应该都知道,到布署阶段再来修改数据库是一件很恐怖的事情。

  最后,使用nvarchar的另一个好处就是在判断字符串的时候可以不需要考虑中英文两种字符的差别,当然,使用nvarchar存储英文字符会增大一倍的存储空间,但是在存储代价已经很低廉的情况下,优先考虑兼容性会给你带来更多好处,所以在设计的时候应该尽量使用nvarchar来存储数据,只有在你确保该字段不会存储中文的时候,再采用varchar来存储。

本文转载自:https://blog.csdn.net/hu_bin1021/article/details/51442515

A
粉丝 0
博文 47
码字总数 6214
作品 0
程序员
私信 提问
SQL Server中nvarchar(max)

SQL Server中,存储较小的数据,可以使用varchar(n)、nvarchar(n) 和varbinary(n)类型,存储大的数据,使用varchar(max)、nvarchar(max)和varbinary(max) 代替 text、ntext和 image 数据类型...

学习也休闲
2015/08/07
948
0
varchar和Nvarchar区别

Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示 如果还为了这个纠结,就直接看看后面的解说,做决定吧。 一般如果...

Yamazaki
2012/06/01
6
0
PostgreSQL Oracle/sql server/SYBASE 兼容性之 - nchar , nvarchar , ntext (unicode character)

标签 PostgreSQL , Oracle , nchar , nvarchar , ntext , ms sql , sybase , unicode character , utf8 背景 在Oracle, MS SQL, SYBASE数据库引擎中,有一些这样的字符串类型nchar , nvarcha......

德哥
04/14
0
0
如何在sql server中把数据库中的日期字段转换为短日期格式

数据库中的字段begintime为2007-4-18 17:37,怎样获得begintime为2007-4-18 这个怎么解决? 解决办法:convert(varchar(10),begintime,120) 用CONVERT 可以实现 使用 CONVERT: CONVERT (dat...

DDwang
2012/10/26
192
0
sp_executesql介绍和使用

execute相信大家都用的用熟了,简写为exec,除了用来执行存储过程,一般都用来执行动态Sql spexecutesql,sql2005中引入的新的系统存储过程,也是用来处理动态sql的, 如: exec spexecutesql ...

zchuanzhao
2016/03/08
13
0

没有更多内容

加载失败,请刷新页面

加载更多

Hibernate 5 的模块/包(modules/artifacts)

Hibernate 的功能被拆分成一系列的模块/包(modules/artifacts),其目的是为了对依赖进行独立(模块化)。 模块名称 说明 hibernate-core 这个是 Hibernate 的主要(main (core))模块。定义...

honeymoose
48分钟前
4
0
CSS--属性

一、溢出 当内容多,元素区域小的时候,就会产生溢出效果,默认是纵向溢出 横向溢出:在内容和容器之间再套一层容器,并且内部容器要比外部容器宽 属性:overflow/overflow-x/overflow-y 取值...

wytao1995
今天
4
0
精华帖

第一章 jQuery简介 jQuery是一个JavaScript库 jQuery具备简洁的语法和跨平台的兼容性 简化了JavaScript的操作。 在页面中引入jQuery jQuery是一个JavaScript脚本库,不需要特别的安装,只需要...

流川偑
今天
7
0
语音对话英语翻译在线翻译成中文哪个方法好用

想要进行将中文翻译成英文,或者将英文翻译成中文的操作,其实有一个非常简单的工具就能够帮助完成将语音进行翻译转换的软件。 在应用市场或者百度手机助手等各大应用渠道里面就能够找到一款...

401恶户
今天
3
0
jenkins 插件下载加速最终方案

推荐做法 1、告诉jenkins 我哪些插件需要更新 jenkins插件清华大学镜像地址 https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json 1.进入jenkins系统管理 2.进入插件管...

vasks
今天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部