加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql-server – 为什么还有varchar数据类型?

发布时间:2021-01-11 16:34:18 所属栏目:MsSql教程 来源:网络整理
导读:我的许多数据库都将字段定义为varchars.自从我在美国生活和工作(其中唯一存在的语言是“美国人”)以来,这并没有太大的问题. 在使用数据库大约5年之后,我发现我最终遇到了varchar字段的有限性问题,我必须修改我的字段以将数据存储为nvarchars.在必须对表进

我的许多数据库都将字段定义为varchars.自从我在美国生活和工作(其中唯一存在的语言是“美国人”)以来,这并没有太大的问题.

在使用数据库大约5年之后,我发现我最终遇到了varchar字段的有限性问题,我必须修改我的字段以将数据存储为nvarchars.在必须对表进行另一次更新之后,将varchar字段转换为nvarchar,我只是想到了 – 为什么我们仍然这样做?我很久以来就决定将我的所有新文本字段定义为nvarchar而不是varchar,这是我10年前在学校时从我的教科书中学到的.

它是2011年,去年有一个新的SQL Server版本.当我们可以/应该使用nvarchar时,为什么我们继续支持varchar数据类型?

我知道经常有人认为nvarchars是varchars的“两倍大”,因此存储空间的使用可能是维持varcars的一个争论.

但是,今天的用户可以定义他们的nvarchars,以便将数据存储为UTF-8而不是默认的UTF-16,如果他们想节省存储空间的话.如果这是主要需要的话,这将允许8位编码,同时保证插入到其DB中的罕见的2-8字节字符不会破坏任何东西.

我错过了什么吗?有没有充分的理由说明为什么在过去15到20年间没有改变?

解决方法

> varchar工作对于许多西欧语言(挪威语,丹麦语,德语,法语,荷兰语等)来说已经足够好了,可能会受到一些整理问题的影响
>在SO varchar vs nvarchar performance上看到这一点nvarchar具有严重的性能影响 >与处理日期MDY和DMY相比,这是微不足道的

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读