首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >当varchar和Nvarchar关联

当varchar和Nvarchar关联

作者头像
薛晓刚-
发布2026-06-25 10:55:30
发布2026-06-25 10:55:30
980
举报

Nvarchar数据类型比较特殊

有开发人员反馈,两个字段关联,一个是varchar、另外一个是Nvarchar,会有性能问题吗?

这个问题其实不能说一定有。通过实验来说明吧。

具体实验-表结构

image.png
image.png
  • A表的VAR列、NVAR列和B表的NVAR列和M列有索引
  • B表的VAR列索引不可见(或者说没有索引)

类型转换

  • VAR列有索引,但是是字符型,给了一个数值。函数转换了,全表扫描
  • 在执行计划中也看到了TO_NUMBER(“VAR”)=1的字样
image.png
image.png

两种类型都有索引情况下

image.png
image.png
image.png
image.png
  • VAR列有索引,所以用到了索引。
  • NVAR列有索引,所以用到了索引。
  • 但是注意NVAR类型列的时候有一个(“NVAR”=U’1’) U。而Var的类型时候没有。

B表VAR关闭索引

  • XXG@xxg> alter index b_var invisible;

索引已更改。

  • 设置B表var列索引不可见。自然是全表查询。
image.png
image.png
  • B表的M列搜索引,可以使用。
image.png
image.png

那么B表通过m列找到的数据传导给A表

image.png
image.png
  • 可以用到索引的。即使b.var的索引不可见。相当于b.m='1’找到了b.var=‘1’ select * from a,b where a.var=‘1’ and b.m=‘1’;
  • 所以关联列在特殊情况下,不是必须两列都有索引。但是这是特殊情况。一般日常中我还是建议,且强制关联列都建立索引。因为我们无法保证都是B表这种作为传导条件的。如果是A表作为传导入口就不行了。
  • 因为在b.var没有索引的情况下。无论执行下面哪种B表都是全表。
image.png
image.png

在B表nvar有索引的情况下,看看索引的使用情况

  • B表nvar有索引的情况下,这个是可以用到索引的。
image.png
image.png
  • 但是只要一关联到A表的VAR列就是全表关联了。
image.png
image.png
  • 那么在其他不变的情况下,而如果是A表的VAR作为传导开始,也是可以都用到索引的。
image.png
image.png
  • 所以这就要求如果两个关联列一个是var一个是Nvar的话,那么要以var的作为条件去查比较好。
  • 从nvar传到var即使a.var列有索引还是发生了转换
image.png
image.png

从var传到nvar即使b.var列现在索引是不可见的,两个表都用到了索引。

image.png
image.png

结论

  • 最好是类型一样
  • 数据库设计由DBA负责而不是开发人员
  • 如果可能的话,改成varchar。避免使用varchar
  • 最好关联列都建立索引
  • 实在不行的话,用var列的条作为入口查询条件。
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2025-08-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 四海内皆兄弟 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Nvarchar数据类型比较特殊
  • 具体实验-表结构
  • 类型转换
  • 两种类型都有索引情况下
  • B表VAR关闭索引
  • 那么B表通过m列找到的数据传导给A表
  • 在B表nvar有索引的情况下,看看索引的使用情况
  • 结论
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档