0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

SQL Server中的VARCHAR和NVARCHAR数据类型

哲想软件 来源:哲想软件 2023-04-10 09:57 次阅读

关系数据库在表中表示组织的数据,这些表使用具有不同数据类型的列,允许它们存储有效值。开发人员和DBA需要知道并理解每一列的适当数据类型,以获得更好的查询性能。

本文将讨论流行的数据类型VARCHAR()和NVARCHAR()、它们的比较以及SQLServer 中的性能评估。

SQL中的VARCHAR[ ( n | max ) ]

该VARCHAR数据类型表示非Unicode可变长度的字符串的数据类型。您可以在其中存储字母、数字和特殊字符。

N表示以字节为单位的字符串大小。

VARCHAR数据类型列最多可存储8000个非Unicode字符。

VARCHAR数据类型每个字符占用1个字节。如果您没有明确指定N的值,则它需要1个字节的存储空间。

注意:不要将N与表示字符串中字符数的值混淆。

以下查询使用100个字节的数据定义VARCHAR数据类型。

58c648ce-d73a-11ed-bfe3-dac502259ad0.png

它返回长度为17,因为每个字符1个字节,包括一个空格字符。

58dda06e-d73a-11ed-bfe3-dac502259ad0.png

以下查询定义了没有任何N值的VARCHAR数据类型。因此,SQLServer 将默认值视为1个字节,如下所示。

59083acc-d73a-11ed-bfe3-dac502259ad0.png

我们还可以通过CAST或CONVERT函数使用VARCHAR。例如,在下面的两个示例中,我们声明了一个长度为100字节的变量,然后使用了CAST运算符。

第一个查询返回长度为30,因为我们没有在CAST运算符VARCHAR数据类型中指定N。默认长度为30。

5928caee-d73a-11ed-bfe3-dac502259ad0.png

但是,如果字符串长度小于30,则取字符串的实际大小。

594d2704-d73a-11ed-bfe3-dac502259ad0.png

SQL中的NVARCHAR[ ( n | max ) ]

所述NVARCHAR数据类型是用于Unicode的可变长度的字符数据类型。这里,N指的是国家语言字符集,用于定义Unicode字符串。您可以存储非Unicode和Unicode字符(日语汉字、韩文等)。

N表示以字节为单位的字符串大小。

它最多可以存储4000个Unicode和非Unicode字符。

VARCHAR数据类型每个字符占用2个字节。如果不为N指定任何值,则需要2个字节的存储空间。

以下查询使用100个字节的数据定义VARCHAR数据类型。

596eeb64-d73a-11ed-bfe3-dac502259ad0.png

它返回36的字符串长度,因为NVARCHAR每个字符存储占用2个字节。

59874df8-d73a-11ed-bfe3-dac502259ad0.png

与VARCHAR数据类型类似,NVARCHAR也有1个字符(2个字节)的默认值,而没有为N指定显式值。

59b0ed20-d73a-11ed-bfe3-dac502259ad0.png

如果我们使用CAST或CONVERT函数应用NVARCHAR转换而没有任何显式N值,则默认值为30个字符,即60个字节。

59d50142-d73a-11ed-bfe3-dac502259ad0.png

以VARCHAR数据类型存储Unicode和非Unicode值

假设我们有一个表,记录来自电子购物门户的客户反馈。为此,我们有一个包含以下查询的SQL表。

59fbf180-d73a-11ed-bfe3-dac502259ad0.png

我们在这个表中插入几个英语、日语和印地语的示例记录。[Comment]的数据类型是VARCHAR,[NewComment]是NVARCHAR()。

5a158a1e-d73a-11ed-bfe3-dac502259ad0.png

查询成功执行,并在从中选择一个值时给出以下行。对于第二和第三行,如果数据不是英语的,它就不能识别数据。

5a3443f0-d73a-11ed-bfe3-dac502259ad0.png

VARCHAR和NVARCHAR数据类型:性能比较

我们不应在JOIN或WHERE谓词中混合使用VARCHAR和NVARCHAR数据类型。它使现有索引无效,因为SQLServer 要求JOIN两侧的数据类型相同。如果不匹配,SQLServer 会尝试使用CONVERT_IMPLICIT()函数进行隐式转换。

SQLServer 使用数据类型优先级来确定目标数据类型。NVARCHAR的优先级高于VARCHAR数据类型。因此,在数据类型转换期间,SQLServer 会将现有的VARCHAR值转换为NVARCHAR。

5a5a8498-d73a-11ed-bfe3-dac502259ad0.png

现在,让我们执行两个SELECT语句,根据它们的数据类型检索记录。

5a74aae4-d73a-11ed-bfe3-dac502259ad0.png

这两个查询都使用索引查找运算符和我们之前定义的索引。

5a8d0472-d73a-11ed-bfe3-dac502259ad0.png

现在,我们切换数据类型值以与WHERE谓词进行比较。第1列具有VARCHAR数据类型,但我们指定N'A'将其作为NVARCHAR数据类型。

类似地,col2是NVARCHAR数据类型,我们指定了引用VARCHAR数据类型的值“C”。

5aba63fe-d73a-11ed-bfe3-dac502259ad0.png

在查询实际执行计划中,您得到一个索引扫描,SELECT语句有一个警告符号。

5acedb86-d73a-11ed-bfe3-dac502259ad0.png

此查询工作正常,因为NVARCHAR()数据类型可以同时具有Unicode和非Unicode值。

现在,第二个查询使用索引扫描并在SELECT运算符上发出警告符号。

5af21b82-d73a-11ed-bfe3-dac502259ad0.png

将鼠标悬停在发出有关隐式转换的警告的SELECT语句上。SQLServer 无法正确使用现有索引。这是由于VARCHAR和NVARCHAR数据类型的数据排序算法不同。

如果表有数百万行,SQLServer必须做额外的工作并使用隐式数据转换来转换数据。它可能会对您的查询性能产生负面影响。因此,在优化查询时应避免混合和匹配这些数据类型。

5b125dca-d73a-11ed-bfe3-dac502259ad0.png

结论

您应该在适当地设计数据库表及其列数据类型时查看您的数据要求。通常,VARCHAR数据类型可以满足您的大部分数据需求。但是,如果需要在列中同时存储Unicode和非Unicode数据类型,则可以考虑使用NVARCHAR。但是,在做出最终决定之前,您应该查看其性能影响、存储大小。

审核编辑 :李倩

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据库
    +关注

    关注

    7

    文章

    3052

    浏览量

    62798
  • 函数
    +关注

    关注

    3

    文章

    3131

    浏览量

    60639
  • 数据类型
    +关注

    关注

    0

    文章

    173

    浏览量

    13331
收藏 人收藏

    评论

    相关推荐

    SQL储存过程等的解密

    nvarchar(4000),@sql2 varchar(8000),@sql3 nvarchar(4000),@sql4 nvarchar(4000)DECLARE @OrigSpText1
    发表于 12-31 16:54

    SQL Server数据库基础知识归纳总结

    sql数据库10个“对象”: 表、视图、触发器、过程、列、索引、约束、规则、默认、用户自定义的数据类型;9、“关系运算”主要有
    发表于 09-18 23:51

    labview读取SQLserver数据库时,nvarchar(max)数据类型的读取方式

    数据库连接工具包问题描述:我正在使用DB工具VIS查询SQL数据库。数据表包含各种SQL数据类型的150列。当使用DB Tools SELECT函数返回与部件编号关联的数据时(部件编号
    发表于 06-18 12:34

    SQL Server 2000菜鸟入门

    SQL Server 2000企业版安装教程(一) SQL Server 2000企业版安装教程(二) SQL Server 2000企业版安装教程(三) SQL Server 2000企业版安装教程(四) SQL
    发表于 12-26 14:08 35次下载

    数据库与SQL Server 2005教程

    SQL Server Management Studio(可称为SQL Server集成管理器,简写为Management Studio
    发表于 04-10 17:43 136次下载

    数据SQL高级应用课程

    SQL Server 2005大值数据类型、事务、游标、分布式查询及XML数据类型等概念。SQL Server 2005引入了max说明符来
    发表于 04-14 16:18 198次下载

    vhdl数据类型

    的标识符可以是常数、变量、信号、端口、子程序或参数的名字。VHDL数据类型可以分成四大类: 标量型(SCALAR TYPE):属单元素的最基本的数据类型,通常用于描述一个单值数据对象
    发表于 03-30 15:59 11次下载

    SQL Server 2005数据库的应用手册

    SQL Server是基于服务器端的中型的数据库,可以适合大容量数据的应用,在功能上管理上要比Access要强得多。下面我们以Microsoft SQL Server 2005为例简单介绍一下SQL Server数据的应用。
    发表于 01-10 08:00 11次下载
    <b>SQL</b> <b>Server</b> 2005<b>数据</b>库的应用手册

    基于LABVIEW的SQL Server数据库操作教程

    SQL Server数据库操作教程
    发表于 09-13 14:54 78次下载

    51单片机数据类型解析

    数据类型数据结构的定义是一个值的集合以及定义在这个值集上的一组操作。数据类型包括原始类型、多元组、记录单元、代数数据类型、抽象数据类型、参考类型以及函数类型。本文主要以51单片机数据类型为中心而展开
    发表于 11-16 08:45 2.1w次阅读

    MySQL支持的三种数据类型

    SQL数字数据类型。这些类型包括整数类型、定点类型、浮点类型和位置
    的头像 发表于 05-03 17:33 2795次阅读
    MySQL支持的三种<b>数据类型</b>

    什么是数据类型转换

    数据类型:1、Python数据类型第一种:字符串(str)。 2、Python
    的头像 发表于 02-23 15:21 238次阅读

    定义数据类型

    数据类型,定义出脚本支持的数据类型,这是运算的基础。 这一小节我们将定义出
    的头像 发表于 03-03 10:10 232次阅读

    ARRAY 数据类型的变量

    数据块已打开。 操作步骤 要声明一个 ARRAY 数据类型的变量,请按以下步骤操作: 在“名称”(Name) 列,输入变量的名称。 在“数据类型”列输入“Array”数据类型。在此步骤
    的头像 发表于 07-06 11:08 155次阅读

    F型PLC数据类型与标准PLC数据类型(UDT)之间的差别在哪?

    数据类型 (UDT) 那样,声明和使用 F 型 PLC 数据类型 (UDT) 。可以在安全程序以及标准用户程序中使用 F 型 PLC 数据类型 (UDT) 。
    的头像 发表于 08-27 09:54 253次阅读
    F型PLC<b>数据类型</b>与标准PLC<b>数据类型</b>(UDT)之间的差别在哪?