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

    文章

    3845

    浏览量

    64667
  • 函数
    +关注

    关注

    3

    文章

    4345

    浏览量

    62946
  • 数据类型
    +关注

    关注

    0

    文章

    236

    浏览量

    13656

原文标题:SQL Server 中的VARCHAR和NVARCHAR数据类型

文章出处:【微信号:哲想软件,微信公众号:哲想软件】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Devart: dbForge Compare Bundle for SQL Server—比较SQL数据库最简单、最准确的方法

      dbForge Compare Bundle For SQL Server:包含两个工具,可帮助您节省用于手动数据库比较的 70% 的时间 dbForge数据比较 帮助检测和分析实
    的头像 发表于 01-17 11:35 130次阅读

    dbForge Studio For SQL Server:用于有效开发的最佳SQL Server集成开发环境

    dbForge Studio For SQL Server:用于有效开发的最佳SQL Server集成开发环境 SQL编码助手
    的头像 发表于 01-16 10:36 101次阅读

    字符串在数据的存储方式

    数据库是现代信息技术存储和管理数据的核心组件。字符串作为最常见的数据类型之一,在数据的存储
    的头像 发表于 01-07 15:41 183次阅读

    AIC23采集到的数据是应该用什么数据类型来接收?int还是unsigned int?

    AIC23采集到的数据是应该用什么数据类型来接收,int还是unsigned int? 这个采集到的数字是什么含义呢?代表的是声音信号的幅值? while(!MCBSP_rrdy(hMcbsp
    发表于 10-18 06:56

    数据数据恢复—SQL Server数据库出现823错误的数据恢复案例

    SQL Server数据库故障: SQL Server附加数据库出现错误823,附加
    的头像 发表于 09-20 11:46 403次阅读
    <b class='flag-5'>数据</b>库<b class='flag-5'>数据</b>恢复—<b class='flag-5'>SQL</b> <b class='flag-5'>Server</b><b class='flag-5'>数据</b>库出现823错误的<b class='flag-5'>数据</b>恢复案例

    labview数据类型的取值范围是多少

    LabVIEW的数据类型丰富多样,涵盖了整数、小数(浮点数)、复数等多种类型,每种类型都有其特定的取值范围。以下是对LabVIEW中常见数据类型取值范围的说明: 整数
    的头像 发表于 09-04 17:33 1330次阅读

    常见的遥感数据类型有哪些

    遥感技术是一种通过遥感器在远离目标的位置获取目标地物的电磁波信息,并进行分析的技术。遥感数据类型繁多,涵盖了从可见光到红外、微波等多个波段,以及不同的数据格式和分辨率。 光学遥感数据 : 全色影像
    的头像 发表于 09-04 14:30 2037次阅读

    干货分享 如何采集OPC DA数据并存储到SQL Server数据库?

    在工业自动化系统,将OPC DA数据采集并存储到SQL Server数据库具有显著的应用价值。本文手把手教您完成这一操作,实现
    的头像 发表于 08-09 10:46 699次阅读
    干货分享  如何采集OPC DA<b class='flag-5'>数据</b>并存储到<b class='flag-5'>SQL</b> <b class='flag-5'>Server</b><b class='flag-5'>数据</b>库?

    技术干货驿站 ▏深入理解C语言:基本数据类型和变量

    在C语言中,数据类型和变量是编程的基础,也是理解更复杂概念的关键。数据类型决定了变量的内存分配、存储范围和操作方式,而变量则是存储数据的容器。本篇文章将从基本数据类型和变量两个方面,带
    的头像 发表于 07-26 17:53 2264次阅读
    技术干货驿站 ▏深入理解C语言:基本<b class='flag-5'>数据类型</b>和变量

    如何在SQL创建触发器

    SQL,触发器(Trigger)是一种特殊类型的存储过程,它自动执行或激活响应表上的数据修改事件(如INSERT、UPDATE、DELETE等)。触发器可以用于维护
    的头像 发表于 07-18 16:01 2093次阅读

    数据数据恢复—SQL Server数据库所在分区空间不足报错的数据恢复案例

    SQL Server数据数据恢复环境: 某品牌服务器存储中有两组raid5磁盘阵列。操作系统层面跑着SQL
    的头像 发表于 07-10 13:54 570次阅读

    ESP32-S3是否支持修改控制端点数据类型

    ESP32-S3是否支持修改控制端点数据类型(如标准类型,自定义类型); 我需要在控制传输数据阶段的DATA0包改为我的USB设备规定的8个字节的
    发表于 06-07 06:00

    数据数据恢复—ndf文件大小变为0KB的数据恢复案例

    存储设备损坏导致存储SQL Server数据库崩溃。对数据库文件进行恢复后,用户发现有4个ndf文件的大小变为0KB。该
    的头像 发表于 05-07 11:19 453次阅读

    数据数据恢复—Sql Server数据库文件丢失的数据恢复案例

    库。存储空间LUN划分了两个逻辑分区。 服务器故障&初检: 由于未知原因,Sql Server数据库文件丢失,丢失数据涉及到3个库,表的数量有3000左右。
    的头像 发表于 04-11 15:38 958次阅读
    <b class='flag-5'>数据</b>库<b class='flag-5'>数据</b>恢复—<b class='flag-5'>Sql</b> <b class='flag-5'>Server</b><b class='flag-5'>数据</b>库文件丢失的<b class='flag-5'>数据</b>恢复案例

    C语言数据类型有哪些

    在 C 语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式。
    发表于 03-20 10:56 514次阅读
    C语言<b class='flag-5'>数据类型</b>有哪些