位置: 编程技术 - 正文

SQL中varchar和nvarchar的基本介绍及其区别(数据库varchar和nvarchar)

编辑:rootadmin

推荐整理分享SQL中varchar和nvarchar的基本介绍及其区别(数据库varchar和nvarchar),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql中varchar和char是不是差不多,sql语句 varchar,sqlserver中varchar和nvarchar,sql varchar,sql中varchar和char是不是差不多,sql中varchar和number比较,sql中varchar和number比较,sql中varchar和nvarchar的区别,内容如对您有帮助,希望把文章链接给更多的朋友!

varchar(n)

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

nvarchar(n)

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

两字段分别有字段值:我和coffee

那么varchar字段占2×2+6=个字节的存储空间,而nvarchar字段占8×2=个字节的存储空间。

如字段值只是英文可选择varchar,而字段值存在较多的双字节(中文、韩文等)字符时用nvarchar

上面是一个总结介绍,通过上面的介绍,可以知道。

varchar(4) 可以输入4个字母,也可以输入两个汉字

nvarchar(4) 可以输四个汉字,也可以输4个字母,但最多四个

char、varchar、nchar、nvarchar的区别

对于程序中的string型字段,SQLServer中有char、varchar、nchar、nvarchar四种类型来对应(暂时不考虑text和ntext),开建立数据库中,对这四种类型往往比较模糊,这里做一下对比。

定长或变长

所谓定长就是长度固定的,当输入的数据长度没有达到指定的长度时将自动以英文空格在其后面填充,使长度达到相应的长度;有var前缀的,表示是实际存储空间是变长的,比如varchar,nvarchar变长字符数据则不会以空格填充,比较例外的是,text存储的也是可变长。

SQL中varchar和nvarchar的基本介绍及其区别(数据库varchar和nvarchar)

Unicode或非Unicode

数据库中,英文字符只需要一个字节存储就足够了,但汉字和其他众多非英文字符,则需要两个字节存储。如果英文与汉字同时存在,由于占用空间数不同,容易造成混乱,导致读取出来的字符串是乱码。Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。而前缀n就表示Unicode字符,比如nchar,nvarchar,这两种类型使用了Unicode字符集。

基于以上两点来看看字段容量

char,varchar 最多个英文,个汉字nchar,nvarchar 可存储个字符,无论英文还是汉字

使用(个人偏好)

如果数据量非常大,又能%确定长度且保存只是ansi字符,那么char能确定长度又不一定是ansi字符或者,那么用nchar;对于超大数据,如文章内容,使用nText

其他的通用nvarchar

char、varchar、nchar、nvarchar特点比较

CHAR

CHAR存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(),那么不论你存储的数据是否达到了个字节,都要占去个字节的空间。

VARCHAR

存储变长数据,但存储效率没有CHAR高,如果一个字段可能的值是不固定长度的,我们只知道它不可能超过个字符,把它定义为 VARCHAR()是最合算的。VARCHAR类型的实际长度是它的值的实际长度+1。为什么"+1"呢?这一个字节用于保存实际使用了多大的长度。从空间上考虑,用varchar合适;从效率上考虑,用char合适,关键是根据实际情况找到权衡点。

TEXT

text存储可变长度的非Unicode数据,最大长度为2^-1(2,,,)个字符。

NCHAR、NVARCHAR、NTEXT

这三种从名字上看比前面三种多了个"N"。和char、varchar比较起来,nchar、nvarchar最多存储个字符,不论是英文还是汉字;而char、varchar最多能存储个英文,个汉字。可以看出使用nchar、nvarchar数据类型时不用担心输入的字符是英文还是汉字,较为方便,但在存储英文时数量上有些损失。所以一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar。

sql server判断数据库、表、列、视图是否存在 1判断数据库是否存在ifexists(select*fromsys.databaseswherename='数据库名')dropdatabase[数据库名]2判断表是否存在ifexists(select*fromsysobjectswhereid=object_id(N'[表名]')andOBJ

一个统计表每天的新增行数及新增存储空间的功能 使用文中提供的代码做一个统计表每天的新增行数及新增存储空间的功能实现步骤如下:1.创建表创建表,存储每天的表空间占用情况CREATETABLE[dbo].[t_rpt_

win7系统安装SQLServer的详细步骤(图文) 首先,如果以前安装的话,要删除干净。我也找了半天的网络资料。1.把原来SQLServer的安装目录C:ProgramFilesMicrosoftSQLServer删除2.所有SQLServer相关的注册表

标签: 数据库varchar和nvarchar

本文链接地址:https://www.jiuchutong.com/biancheng/321245.html 转载请保留说明!

上一篇:在sql中不指定Order by排序是按照主键吗(oracle sql 不等于某个字符)

下一篇:sql server判断数据库、表、列、视图是否存在(sqlserver判断数字)

  • 在报税显示缺少发票信息
  • 一般纳税人什么条件
  • 什么时候贷主营业务成本
  • 公司股东和自然人股东可否代持股权
  • 研发费用可以计入哪个科目
  • 机票发票打印有效期多久
  • 资产证券化会计准则
  • 息税折旧摊销前利润减去所得税
  • 跨境电商怎么交税
  • 非居民企业股权转让协议
  • 如何知道企业是查账征收还是核定征收
  • 应交增值税减免税款账务处理
  • 应征增值税不含税销售额(3%征收率)怎么算
  • 出口退税预审在申报系统怎么做
  • 变更办税人信息在哪变更
  • 工资为负数需要给公司吗
  • 加盟费收入如何入账
  • 住房公积金管理官网
  • 住房公积金个人缴费比例
  • 定额发票存根要盖章吗
  • 款已付发票未到怎么做结转成本
  • php 反射 性能
  • 银行电子承兑到期了怎么兑现操作
  • 保险税前扣除比例是多少
  • 硬盘最小的存储单位
  • 银行存放中央银行准备金是什么类科目
  • 不能抵扣的发票可以做成本吗
  • 计提坏账准备和转销坏账准备
  • joomla模板制作教程
  • 真菌感染手指甲空了
  • stm32f103教程
  • vscode前端必备扩展
  • vue知识点汇总
  • 坏账的资产减值损失可以税前扣除吗
  • 年报企业所得税的分录怎么做
  • 企业转让时应收账款如何处理
  • 新法典离职
  • 固定资产一次性折旧账务处理
  • 对公账户和私人账户怎么区分
  • 应付职工薪酬属于什么会计科目
  • 个人所得税其他扣除300一个月
  • 新成立的公司企业所得税
  • sql server 2008怎么使用sql语句
  • 一般纳税人未申报可以开票吗
  • 什么是虚开增值发票
  • 一次性扣除固定资产出售处理
  • 企业会计凭证怎么写
  • 结构性存款现金流量表流入里放在哪里
  • 对方多开票账务会怎么样
  • 销货清单和发票金额不一致
  • 收到其他公司往来款怎么做账
  • 预付账款跨年处理分录
  • 自产自销农产品免税备案取消
  • 贴现收到票据时会计分录
  • 发票已到款未付怎么做账
  • 购买食品应注意哪些问题?
  • SQL Server在AlwaysOn中使用内存表的“踩坑”记录
  • win10安装mysql教程
  • mysql登录失败处理
  • win2000服务器
  • win8.1升级win10系统
  • 配置windows server 2008
  • windows图片密码
  • Linux系统网络配置
  • 安装xps虚拟打印机
  • ubuntu查cpu信息
  • win10事件查看器好多错误
  • windows视频截屏
  • windows 10运行
  • opengl源码在哪里
  • 网页设计中span
  • json web key
  • 从零开始学什么技术
  • 介绍一个简单的实验
  • jquery日期控件 datepicker
  • javascript flash下fromCharCode和charCodeAt方法使用说明
  • javascript开关
  • 由简入繁是成语吗
  • 安卓cts认证
  • 农业银行联行号查询系统官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设