位置: 编程技术 - 正文

SQL Server数据类型char、nchar、varchar、nvarchar的区别浅析(sql server数据类型明明放的是浮点型,老是说是其他的)

编辑:rootadmin

推荐整理分享SQL Server数据类型char、nchar、varchar、nvarchar的区别浅析(sql server数据类型明明放的是浮点型,老是说是其他的),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql server数据类型明明放的是浮点型,老是说是其他的,sql server数据类型明明放的是浮点型,老是说是其他的,sqlserver数据类型转换函数,sql server数据类型为货币字段大小为1语句怎么写,sqlserver数据类型转换函数,sql server数据类型转换,sql server数据类型转换,sqlserver数据类型转换函数,内容如对您有帮助,希望把文章链接给更多的朋友!

在SQL Server中,当我们设置字符型字段的时候,往往有很多个数据类型供我们选择,如:char nchar varchar nvarchar等,那么我们到底应该选择哪一个呢?下面就一一来描述其区别。

char:固定长度,非Unicode字符数据,长度为n个字节。n的取值范围为1至8,,存储大小是n个字节。char的SQL同义词为character。

varchar:可变长度,非Unicode字符数据。n的取值范围为1至8,。max指示最大存储大小是2^-1个字节。存储大小是输入数据的实际长度加2个字节。所输入数据的长度可以为0个字符。SQL-中的varchar就是charvarying或charactervarying。

nchar:n个字符的固定长度的Unicode字符数据。n值必须在1到4,之间(含)。存储大小为两倍n字节。nchar的SQL-同义词为nationalchar和nationalcharacter。

nvarchar:可变长度Unicode字符数据。n值在1到4,之间(含)。max指示最大存储大小为2^-1字节。存储大小是所输入字符个数的两倍+2个字节。所输入数据的长度可以为0个字符。nvarchar的SQL-同义词为nationalcharvarying和nationalcharactervarying。

char,varchar:最多个英文,个汉字

nchar,nvarchar:可存储个字符,无论英文还是汉字

SQL Server数据类型char、nchar、varchar、nvarchar的区别浅析(sql server数据类型明明放的是浮点型,老是说是其他的)

char,nchar:定长,速度快,占空间大,需处理

varchar,nvarchar:变长,速度慢,占空间小,无需处理

定长就是长度固定的,当输入的数据长度没有达到指定的长度时将自动以英文空格在其后面填充,使长度达到相应的长度。

变长字符数据则不会以空格填充,比较例外的是,text存储的也是可变长。

1、char。char存储定长数据很方便,char字段上的索引效率级高,比如定义char(),那么不论你存储的数据是否达到了个字节,都要占去个字节的空间,不足的自动用空格填充,所以在读取的时候可能要多次用到Trim()。

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

3、nchar、nvarchar、ntext。这三种从名字上看比前面三种多了个“n”。它表示存储的是Unicode数据类型的字符。我们知道字符中,英文字符只需要一个字节存储就足够了,但汉字众多,需要两个字节存储,英文与汉字同时存在时容易造成混乱,Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。nchar、nvarchar的长度是在1到之间。和char、varchar比较起来,nchar、nvarchar则最多存储个字符,不论是英文还是汉字;而char、varchar最多能存储个英文,个汉字。可以看出使用nchar、nvarchar数据类型时不用担心输入的字符是英文还是汉字,较为方便,但在存储英文时数量上有些损失。

所以一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar。

SQL Server中检查字段的值是否为数字的方法 最近有一个项目,需要检查某个字符型字段的值是否为数字,由于数据行是海量,所以需要通过SQL语句来筛查,这里拿来做个备忘。用到的函数为IsNumeri

SQL Server出现System.OutOfMemoryException异常的解决方法 今天在用SQLServer执行一个SQL脚本文件时,老是出现引发类型为System.OutOfMemoryException的异常错误,脚本明明是从SQLServer导出的,应该不会出错,研

SQL Server 安全配置详解 SQLserver数据库应用非常广泛,一旦出现安全问题,造成的损失往往难以估量!应提前预防,防患于未然。这里,我们主要谈论有关SQLServer数据库的

标签: sql server数据类型明明放的是浮点型,老是说是其他的

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

上一篇:SQLServer行转列实现思路记录(sqlserver行列转换多行多列)

下一篇:SQL Server中检查字段的值是否为数字的方法(检查sqlserver是否安装完成)

  • 如何判断销售额含税还是不含税
  • 外出经营活动税收管理证明在哪里办理
  • 非营利组织营利了怎么办
  • 新成立的公司如何建账
  • 计提个税会计分录怎么做小规模
  • 处置固定资产增值税税率
  • 兼职会计负责的工作内容
  • 实收资本属于限定性净资产吗
  • 电子税务局如何变更财务负责人
  • 消费税为什么要计入成本
  • 总公司是一般纳税人吗
  • 对外销售产品
  • 公司员工个人所得税
  • 新会计准则开办费装修费计入什么科目
  • 企业印花税算法
  • 企业所得税征收标准2023
  • 股权交易要不要缴纳印花税?
  • 营改增公告
  • 增值税发票地址开错了有影响吗
  • 饭店收停车费
  • 坏账处理的所得税税率
  • 坏账核销谁来审批
  • 委托代销商品委托方发出商品的分录
  • 水利基金免税额度是多少
  • 公司购酒的发票可以开多少
  • 公司净资产怎么算出来的
  • 进项税和销项税怎么抵扣
  • 交易性金融资产属于什么科目
  • php初学
  • 公司已开工程发票怎么开
  • 莱姆 惨败
  • 货物运输业增值税专用发票
  • php返回函数值的关键字
  • 微信第三方登录信息修改
  • php数据库编程
  • 富文本编辑器和markdown编辑器的区别
  • web前端基础教程
  • linux用cat命令查看
  • 手机开的发票
  • 冲减管理费用为什么放在借方
  • 金税盘服务费可以跨年抵扣
  • 管理费用属于什么类
  • 织梦建站详细步骤
  • 爬虫技术是做什么的
  • 安装和使用蓄能器应注意哪些问题
  • php 操作mongodb
  • mongodb的坑
  • 获取gridview某行某列的值
  • sql文件压缩
  • 装修室内设计效果图
  • 不动产拆除的收入处理
  • 发票开错一个字还能报销吗?
  • 捐赠,广告宣传费,业务招待费如何调整
  • 损益类科目如何记忆
  • 经营利润所得税费用
  • 私人借款条怎么写合法
  • 用于出租的设备属于什么资产
  • 什么叫进项税率
  • 利润表中财务费用中的利息费用和利息收入
  • 多计提的税款会计处理
  • mysql数据库中文
  • winxp u盘拒绝访问
  • Windows Server 2008网络中禁止迅雷下载
  • ubuntu :wq
  • Windows RT 8.1 Update 3新特性曝光 9月推出
  • win8系统没有声音怎么办
  • wire软件下载
  • 猫的所有视频
  • js实现功能
  • 批处理文件可用记事本
  • 法线贴图使用
  • redis基础教程
  • python抓取手机号软件
  • js clearInterval()方法的定义和用法
  • js获取鼠标坐标到浏览器底部
  • jquery search
  • android学什么
  • 书画作品赠送仪式
  • 地税可以补开以前发票吗
  • 税控盘服务费必须每年交吗为什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设