位置: 编程技术 - 正文

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

  • 房产税城镇土地使用税税率
  • 计提工会经费的科目
  • 计提坏账所得税费用分录
  • 股东公司
  • 技术成果投资入股企业所得税递延纳税备案表
  • 商贸企业印花税税率
  • 流转税收入怎么算
  • 短期借款有哪些
  • 房地产行业预缴税款
  • 库存商品低价销售违法吗
  • 建筑业挂靠核定征收会计分录怎么写?
  • 印花税金额不足多少可以不收
  • 软件开发的服务内容方式要求
  • 多缴的增值税能退吗
  • 公司筹建期的个税怎么交
  • 房地产企业开发成本计入存货
  • 税务稽查是什么
  • 外地预缴城市建设2%的依据
  • 公司账上亏损
  • 付工程款现金怎么做凭证?
  • 存出资本保证金属于什么科目
  • 软件维护费清单
  • 员工意外伤害保险怎么买
  • 主板bios在线升级
  • 怎么给自己的宽带改名字
  • 弥补亏损需要注意的事项
  • 呆账核销的条件有哪些
  • php生成随机数字
  • PHP:imagecreatefromstring()的用法_GD库图像处理函数
  • 企业所得税的税收筹划
  • 工伤报销入账
  • composer环境变量
  • 职工报销医药费属于什么会计科目
  • 当月没有生产情况正常吗
  • yolo系列算法比较
  • modprobe operation not permitted
  • 亏损弥补政策
  • 营业执照贴印花税票吗
  • 成本费用做账
  • 采购的技术服务费会计分录
  • 辞退员工补偿金计入什么科目
  • 解决烧心最快方法
  • 股权变更如何交税
  • mysql查询字段为空的数据
  • 租房合同 陷阱
  • 修理费用的会计怎么做账
  • 股东捐赠给企业怎么做账
  • 关税计入什么科目
  • 生产车间制造产品领用材料45000元,领用车间一半消耗
  • 生产成本直接人工怎么算
  • chrome浏览器81.0
  • u盘ghost装机
  • 如何禁止mac adobe acrobat联网
  • osk.exe
  • win8怎么打开系统设置
  • mac的itunes怎么用
  • win10拖动窗口快捷键
  • win10 edge浏览器崩溃
  • linux如何创建ftp
  • windows7旗舰版怎么打字
  • win8控制面板怎么打开
  • gridview获取列数据
  • 实现高性能化 两个字表达
  • js判断密码强弱
  • 谈谈对环境保护认识话题三分钟
  • 何为黄金茶
  • android studio打包jar文件
  • python中类怎么用
  • Jquery AJAX POST与GET之间的区别详细介绍
  • android基础入门教程
  • jquery中可以用什么方法来获取和设置元素属性
  • 获取手机信息的渠道
  • python3 flask
  • jquery实现图片横向移动
  • 广西国家税务局官网
  • 辽宁新农合怎么停保
  • 小规模出售不动产怎么交税
  • 印花税怎么计提和结转
  • 广东省社保缴费基数
  • 普宁市离揭阳市有多远
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设