位置: 编程技术 - 正文

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判断数字)

  • 报税残疾人保障费怎么算
  • 税务师考几科几分及格
  • 个税系统经营所得如何添加人员信息
  • 个税填报后怎么撤销申报
  • 如何查询对方是不是一般纳税人
  • 新公司利润表怎么填
  • 不动产融资租赁税率是多少
  • 向个人借款计入什么会计科目
  • 没有票据怎么要账
  • 厂房怎么计提折旧费
  • 收到政府补助的固定资产的账务处理
  • 工程安装公司暂估人工费如何做会计核算?
  • 无形资产出租后还要摊销吗
  • 股权转让后没有给转让费怎么办
  • 非独立核算的分公司注销流程
  • 职工死去还有工资吗
  • 季报所得税可以预交吗
  • 转股交印花税的优惠政策
  • 企业所得税审计的内容包括哪四个方面
  • 夫妻双方交契税可以一人到嘛
  • 汇算清缴差旅费扣除标准
  • 公司向职工借款不还怎么办理
  • 当月认证下月抵扣
  • 小规模减征额哪些项目
  • 物业管理体现在哪些地方
  • 应收账款及票据
  • 以前的员工怎么交社保
  • 稽查查补税款怎么计算企业所得税
  • 月末计提短期借贷利息
  • 公司注销时债权人未申报债权
  • 个人所得税款项性质
  • 本年利润余额的计算公式
  • 基本户是否可以冻结
  • php redis实现秒杀思路
  • 商业承兑汇票提示承兑期限
  • nvsvc.exe - nvsvc是什么进程 有什么用
  • 入库的原材料单价怎么求
  • vue播放rtsp视频流
  • javascript postmessage
  • 土耳其棉花堡位置
  • 数据库操作实例
  • 小微企业资金数额
  • window cuda
  • 大前端入门指南
  • 深度学习论文精读[6]:UNet++
  • print函数php
  • 帝国cms功能
  • phpweb缓存技术
  • 盈余公积金的账务处理
  • 工厂院里栽什么树好呢
  • 公司注销剩余的发票怎么作废
  • 合同补充协议印花税怎么交
  • 不动产进项税额抵扣从什么时候开始
  • sql server如何删除
  • mysql8绿色版安装
  • 职工社会保险费是什么意思
  • 公对公转账货款写成了往来款怎么办
  • 中小企业收款
  • 电子缴税付款凭证怎么做记账凭证
  • 中标服务费可以税前扣除吗
  • 企业自建厂房需要有资质吗
  • 跨月报销的凭证有哪些
  • 购车预付款交了可以退吗
  • 房地产开发企业销售自行开发的房地产项目
  • 航天开票系统怎么导出已开票明细
  • mysql5.6允许远程连接
  • win8的文件夹选项在哪里
  • xbox无法连接无线网络
  • centos双网卡配置
  • ubuntu16.04远程连接
  • gnaupdaemon.exe是什么
  • pcc是什么文件
  • win7装win8系统教程
  • win7无网激活
  • perl cgi
  • vuejs单页面
  • jQuery Easyui Tabs扩展根据自定义属性打开页签
  • javascript函数如何定义及其作用
  • 诺诺开票软件怎么领用发票
  • 北京税务热线电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设