位置: 编程技术 - 正文

浅析SQL Server的分页方式 ISNULL与COALESCE性能比较(sql server干嘛的)

编辑:rootadmin

推荐整理分享浅析SQL Server的分页方式 ISNULL与COALESCE性能比较(sql server干嘛的),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:简述sql server,sql server干嘛的,简述sql server的优点,简述sql server的优点,sql server干嘛的,sql server的相关技术知识,sql server有什么作用,sql server有什么作用,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

上一节我们讲解了数据类型以及字符串中几个需要注意的地方,这节我们继续讲讲字符串行数同时也讲其他内容和穿插的内容,简短的内容,深入的讲解。(可参看文章《详解SQL Server中的数据类型》)

分页方式

在SQL 或者SQL 中我们是利用ROW_NUMBER开窗函数来进行分页的,关于开窗函数,我们在SQL进阶中会详细讲讲。如下:

上面代码想必就不需要我解释了,同时利用视图也可以进行分页

下面我们来看看这二者利用SQL查询语句和视图有没有性能上的差异呢?来,检验就是。

从这里我们可以看出,二者在性能开销上并没有什么不同,大部分情况下应该是一样的。但是在SQL 之后版本则出现新的语法来实现分页,估计我们依然还是利用的ROW_NUMBER,可能是为了能够兼容SQL版本到,利用OFFSET-FETCH来进行筛选过滤,它是基于SQL 之后才有。上述我们是取从到之间的数据,如果用OFFSET-FETCH实现,我们看这个函数字面意思就能知道跳过多少数据然后抓取多少数据,所以我们需要跳过前面条数据,需要取接下来条数据。

如果对SQL版本要求不低的话,利用OFFSET-FETCH来实现简直爽爆了。

COALESCE compare to ISNULL

上一节我们讲了讲一些字符串函数,其中漏掉了一个字符串函数即COALESCE,这个函数在SQL +上才有,其中还有其他几个类似对字符串函数的处理,我们一起来看下。msdn对其定义为:按顺序计算变量并返回最初不等于 NULL 的第一个表达式的当前值。返回数据类型优先级最高的 expression 的数据类型。 如果所有表达式都不可为 Null,则结果的类型也不可为 Null。如果所有参数均为 NULL,则 COALESCE 返回 NULL。至少应有一个 Null值为NULL 类型。说白了就是对NULL的处理。我们简单来看下一个例子。

上述我们可以看到,我们通过COALESCE函数来对NULL用空字符串来代替进行处理。SQL 也引入了CONCAT函数来接收一个要连接的输入列表并自动以空字符串替换NULL,上述同样可以用CONCAT函数来代替。

同时我们看到下图知道,CONCAT函数参数至少要有两个:

msdn对CONCAT函数解释为:CONCAT 采用可变数量的字符串参数,并将它们串联成单个字符串。 它需要至少两个输入值;否则将引发错误。 所有参数都隐式转换为字符串类型,然后串联在一起。 Null 值被隐式转换为空字符串。 如果所有参数都为 Null,则返回 varchar(1) 类型的空字符串。 隐式转换为字符串的过程遵循现有的数据类型转换规则。

我们继续回到COALESCE函数,主要看看它与ISNULL函数的区别。

COALESCE与ISNULL函数探讨

可能有些人认为ISNULL比COALESCE函数更快,或者有人认为ISNULL和COALESCE函数是等同,更有人认为应该倾向于使用COALESCE函数,因为它是 ANSI SQL标准函数。认为归认为,那么两者到底有何不同呢,我们一起来看下。

(1)COALESCE和ISNULL处理数据类型优先不同

COALESCE函数决定类型输出基于数据类型优先【data type precedence】,所以如下在处理INT时,DATETIME优先级高于INT。

而对于ISNULL函数,数据类型不受数据类型优先影响,而是通过函数参数列表第一项影响,ISNULL在于交换而COALESCE在于所有参数查询的合并。

我们看看进行如下操作会如何

此时会出现无法将DATETIME转换为INT

此时我们需要显式进行如下转换才行

(2)ISNULL会造成数据丢失

我们再来看二者的对比的例子

上述我们定义字符串变量长度为5,而利用ISNULL字符串却被截取了,在这里我们可以认为ISNULL会导致数据的丢失而非出错。为什么会出现这样的结果呢?上述我们已经讲过ISNULL受第一个参数影响,其长度定义为5,所以只能为5,这是会进行截取,而COALESCE函数着眼于检测所有元素,此时为所以会完全进行返回。我们通过运行如下就可以看出。

浅析SQL Server的分页方式 ISNULL与COALESCE性能比较(sql server干嘛的)

我们看到上述COALESCE合并的结果是可空的而ISNULL不是,有一点点不同。

(3)COALESCE对列计算时需要持久化

接下来我们看看二者最大的不同,我们通过计算列并且在其上面创建主键或者非空约束,看看ISNULL和COALESCE的区别

我们再来看看COALESCE函数来计算列

很明显我们需要对列进行持久化,通过添加PERSISTED关键字,如下即可。

我们再来看看一个二者的不同

我们到这里其实我们可以稍微概括下二者的区别:ISNULL着重于替换,而COALESCE着重于合并。COALESCE显示忽略了NULL并用空字符串填充并压缩,而ISNULL对NULL会用空字符串填充但不会压缩。

(4)COALESCE函数支持超过两个参数

对于多个参数输入,ISNULL函数需要嵌套调用,而COALESCE能够处理任何数量,至于上限不知,所以对于多个参数使用COALESCE更加,如下使用多个参数输入。

SELECT COALESCE(a, b, c, d, e, f, g) FROM dbo.table;

而对于ISNULL,我们需要这样做

SELECT ISNULL(a, ISNULL(b, ISNULL(c, ISNULL(d, ISNULL(e, ISNULL(f, g)))))) FROM dbo.table;

二者最终执行时和利用CASE一样

(5)COALESCE和ISNULL二者性能比较

我们来运行如下查询

我们有查询四个场景:(1)两个参数都为NULL(2)第一个参数为NULL(3)第二个参数为NULL(4)两个参数都为NULL。每个场景测试十次,最终得出如下结果

从上看出二者性能并未有什么太大差异,我们不需要太担心了吧,当然上述场景并未完全覆盖,至少还是能说明一部分。上述我们得到的结果查看的执行时间,现在我们再来看看二者查询执行计划。

上述可能不太准确,还和硬件配置有关,也有可能COALESCE的性能差与ISNULL。二者性能应该是没什么很大差异。

(6)ISNULL和自然语言描述不一致

为何是和自然语言描述不一致呢?也就是说我们当判断某个值为NULL会做什么,不为NULL再做什么,这时用查询语言SQL描述如下:

我们用自然语言角度来看,翻译为如果something为NULL我们做什么,这个时候是不一致的。因为在SQL Server中没有布尔值类型,上述我们只能进行如下转换

(7)利用GUID看看奇葩的ISNULL

在本节介绍之前我们再来看看一个例子,从而颠覆你的想法,让你发狂。

SELECT ISNULL(NEWID(), 'JeffckyWang') AS Col1

这样看是没问题,我们将其插入到表中,再看对其列的描述

表中数据确实存在,但是对列的描述是可空的。

总结

上述重点讲述了COALESCE和ISNULL函数区别之处,通过本节的讲述二者的场景和区别,我们是不是应该有了一点想法,到底是该用COALESCE还是ISNULL呢?大部分情况下还是利用COALESCE为好,一是此函数是作为SQL标准函数,第二个相对于ISNULL它可以支持更多参数,而ISNULL则需要嵌套,而对于ISNULL难道就没有应用场景了吗,当然有在查询数据时判断数据是否为NULL,这种情况下利用ISNULL,例如,如下

本文关于ISNULL和COALESCE的比较参考文章:Deciding between COALESCE and ISNULL in SQL Server。本节我们到此结束,简短的内容,深入的理解,我们下节再会,good night!

标签: sql server干嘛的

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

上一篇:详解SQL Server中的数据类型(sql server的sql语句)

下一篇:浅述SQL Server的聚焦强制索引查询条件和Columnstore Index(sql server概述)

  • 财产和行为税合并申报
  • 对方给我公司开的红字发票如何查询
  • 财政补助资金是什么意思
  • 出租土地使用权属于出租不动产吗
  • 暂估材料收到发票后是更正还是红冲
  • 应收票据属于其他应收账款吗
  • 什么是非关联方交易
  • 电子发票作废了还能恢复吗
  • 开票软件找不到已开发票
  • 员工报销公司是哪个部门
  • 工商银行资产负债表
  • 月初结存材料成本差异
  • 房地产企业内部查账查什么
  • 投资公司收回投资款
  • 个税申报系统中年收入不超6万元的确认错了怎么改
  • 已经缴纳税款怎么作废申报
  • 在建工程如何抵扣个税
  • 资管产品增值税征收管理规定
  • 计提坏账准备需要纳税调增吗
  • 财务软件操作指南
  • 企业资产利润率计算公式
  • 出纳收到汇票如何登记
  • 个人挂靠公司按揭购车账务怎么处理?
  • 房租付款和发票有关系吗
  • 金融服务的手续费要交税吗
  • php中strcmp函数
  • 招投标公司需要什么条件
  • u盘格式化后怎么还原数据
  • php数组函数输出《咏雪》里有多少"片"字
  • 罚款收入营业外收入还是其他应收款
  • 境外所得税抵免汇率
  • 公司为员工投保意外险,意外险赔付给谁
  • 阿德莱德 景点
  • vue怎么用elementui
  • 境外机动车临时可以办理什么车险业务
  • 新会计准则关于公司装修费
  • yii框架连接数据库
  • 生物制品简易征收文件
  • gps定位器怎么开启
  • 开源模型:小羊驼(Vicuna-13B),可达chatGPT九成效果。
  • Node.js安装过程
  • 固定资产暂停使用期间需要计提折旧吗
  • mongodb 入门
  • python读取不到文件怎么办
  • 固定资产怎么确认价值
  • 土石方费用入什么科目
  • 以权益结算的股份
  • 应交税费的核算范围
  • 小微企业的所得税税率是多少
  • 个人所得税应纳税额
  • 农民专业合作社税收优惠政策
  • 收到去年的普通发票
  • 维修设备增值税税率
  • 外汇收入需要缴纳增值税吗
  • 网络服务费怎么入账
  • 还借款收据怎么写
  • 应收票据到期收回的会计分录
  • 核销贷款收回账务怎么做
  • mysql a.
  • centos6.5修改用户名
  • windows10mode
  • xp系统的程序和功能在哪里
  • win7系统的虚拟内存在哪里
  • linux如何创建ftp
  • linux系统如何禁用光驱
  • win7系统电脑开机密码怎么设置
  • 搞定immutable.js详细说明
  • Extjs中DisplayField的日期或者数字格式化扩展
  • javascript数据结构与算法第三版
  • 需要牢记的号码
  • vue中使用ajax
  • unity study
  • android GridView实现图库预览图,多选模式下右上角打勾
  • javascript开发基础
  • 怎么知道自己的城乡属性
  • 深圳市保安证办理流程
  • 税务局科员是什么职业
  • 内蒙古税务总局网站官网
  • 漳州市税务局电话多少
  • 退契税的时间是什么时候
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设