位置: 编程技术 - 正文

SQL性能优化之定位网络性能问题的方法(DEMO)(sql效率优化)

编辑:rootadmin

推荐整理分享SQL性能优化之定位网络性能问题的方法(DEMO)(sql效率优化),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:如何优化sql性能,sql性能调优的方法,sql server性能优化与管理的艺术,sql语句性能优化,sql语句性能优化,如何优化sql性能,sql性能优化策略有哪些,sql 性能优化,内容如对您有帮助,希望把文章链接给更多的朋友!

最近项目组同事跟我说遇到一个SQL性能问题,他说全表只有条记录,客户端执行耗费了两分多钟,很不科学。我帮了分析出了原因并得到解决。下面小编安装类似表结构,构造了一个案例,测试截图如下所示:

这个表有KB(也就是M多大小),因为该表将图片保存到数据库(Item_Photo字段为iamge类型),这个是历史原因,暂且不喷这种的设计。看来这个SQL执行时间长的性能问题不在于IO和SQL本身执行计划是否有问题,而是在网络数据传时间上(服务器与客户端位于异地,两地专线带宽6M,不过很多应用、邮件、系统都依赖此专线)

为了验证我的想法,我在服务器本机测试时间为2秒,如下截图所示

从上面我们知道在客户端执行完该SQL语句,总共耗费了2分秒。那么客户端的到底获取了多少字节数据,数据传输耗费了多长时间呢? 能否查看这些DETAIL信息呢? 答案是可以。在SSMS工具栏,勾选“Include Client Statistics”或使用快捷键SHIFT+ALT+S,然后执行SQL语句,就能得到如下截图的相关信息。

Client Statistics(客户端统计信息)包含三大块: Query Profile Statistics, Network Statistics, Time Statistics。这些部分的内容很容易理解,无需多说,那么我们来看看吧

Network Statistics(网络统计信息) Number of server roundtrips: 服务器往返的次数 TDS packets sent from client: 从客户端发送的TDS数据包(个数) TDS packets received from server: 从服务端接收的TDS数据包(个数) Bytes sent from client: 从客户端发送的字节数 Bytes received from server: 从服务器接收的字节数 Time Stattistics:(时间统计信息) Client processing time: 客户端处理时间 Total execution time: 总执行时间 Wait time on server replies: 服务器应答等待时间

从客户端发送的字节和从服务端接收的数据大小都很清晰、明了,那么数据从服务器端发送给客户端所需的时间这里没有,其实它基本上接近客户端处理时间(Client processing time),我们也可以将客户端处理时间权当网络数据传输时间,从上面案例,我们可以看到这个时间耗费了秒( ms),可以肯定这个SQL性能慢在网络数据传输上,而不是慢在数据库那一块(Server Processing Time).

SQL性能优化之定位网络性能问题的方法(DEMO)(sql效率优化)

我们来看看下图,这个是SQL SERVER的请求接收和数据输出的一个大致流程图,当客户端发送请求开始,当服务器接收客户端发来的最后一个TDS包,数据库引擎开始处理请求,请求完成后,将数据发送给客户端,从图中可以看出,客户端接收服务器端返回的数据也是需要一个过程的(或者说时间)

我们在SQL优化过程中,如果一个SQL出现性能问题时,我们应该站在一个全局的角度来分析问题,从CPU资源、网络带宽、磁盘IO、执行计划等多方面来分析,这样才能有助于你分析、定位问题根源,而不要只要SQL响应很慢时,就一味条件反射式先入为主:这是数据库问题。数据库也不能老背这个黑锅。

在数据库等待事件中,ASYNC_NETWORK_IO可以从另外一个侧面反映网络性能问题。关于ASYNC_NETWORK_IO等待类型:

This waittype indicates that the SPID is waiting for the client application to fetch the data before the SPID can send more results to the client application.

那么回到如何优化这个SQL的问题上来,我们可以从下面几个方面来进行优化。

1: SQL只取必须的字段数据

像这个案例,其实它根本不需要Item_Photo字段数据,那么我们可以修改SQL,只取我们需要的字段数据,就可以避免这个问题,提高SQL性能,另外根据我的经验,开发人员习惯性使用SELECT *,从不管那些数据是需要还是不需要的,先全部取过来再说,这种习惯性行为确实不是一个好习惯。

2:避免这种脑残设计

图片应该以文件形式保存在应用服务器上,数据库只保存其路径信息,这种将图片保存到数据库的设计纯属脑残行为。

以上所述是小编通过一个小demo给大家介绍的SQL性能优化之定位网络性能问题的方法,希望对大家有所帮助!

SQL Server 里的sys.dm_exec_input_buffer的问题 我们都知道DBCC命令有点尴尬,因为你不能在T-SQL查询里调用它们,你也不能关联它们的输出到其它DMV/DMF。例如你想为每个用户会话返回最后一个执行的S

SQL Server删除表及删除表中数据的方法 本文介绍SQLServer中如何删除表,如何删除表中的数据。在删除表数据时有delete和truncate两种方法,delete和truncate有什么区别呢?SQLServer,我们现在基本上

sqlserver 因为选定的用户拥有对象,所以无法除去该用户的解决方法 现象:把之前备份的数据库还原到现在的SQL数据库中,现在要把数据库中的用户删除掉,结果却提示:因为选定的用户拥有对象,所以无法除去该用户

标签: sql效率优化

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

上一篇:探讨select in 在postgresql的效率问题(select )

下一篇:SQL Server 2016里的sys.dm_exec_input_buffer的问题(sql server 2016使用)

  • 个人所得税汇算清缴截止日期
  • 小规模纳税人税率1%政策到什么时候
  • 房地产开发公司排名
  • 单位购买理财产品需要什么手续
  • 已收保证金
  • 税控盘服务商
  • 财务毛利率是毛利率吗
  • 胶水开票开什么类目
  • 自产农产品增值税申报表填10行吗
  • 企业减免税享受什么
  • 银行存款支付现金股利属于什么科目
  • 房地产企业对外投资案例
  • 外商投资企业是中国企业吗
  • 长期股权投资的4个明细科目
  • 短期借款会计核算
  • 公司交的物业费入什么科目
  • 其他货币资金包括的内容有
  • 卖下脚料怎么做分录
  • 建筑图纸设计费包括晒图费吗
  • 报销个人费用如何定性
  • 买车的保险可以砍价吗
  • 利息股息红利所得个人所得税怎么算
  • 房地产开发企业销售自行开发的房地产项目
  • 个体工商户个人所得税怎么计算
  • 增值税发票收款人和复核人可以一个人吗
  • 个体户金税盘清卡失败怎么办
  • 代数分配法适用于什么
  • 车辆购置税能抵扣税款吗
  • 交强险是不是只要有发票就可以报销
  • 购买小汽车增值税发票金额开错
  • 开业好不好
  • 物流公司货车报废款怎么做账
  • 待处理财产损益科目编码
  • 向客户发放,赠品怎么写
  • win10闹钟设置方法
  • 存货跌价准备会影响利润吗
  • 主营业务成本算损益类科目吗
  • 法律规定公司必须要有的制度
  • 收到客户付款 会计分录
  • php字符串函数有哪些
  • 发票作废的政策规定
  • avgserv9.exe是什么进程 avgserv9进程的详细介绍
  • 深度学习和日常代码中遇到的报错汇总及解决方案,持续更新中。。。。
  • php wechat
  • 工程项目会计怎么样
  • 对外投资概述
  • 出售固定资产申报表收入与损益表收入不一致
  • 资产负债表的编制方法和步骤
  • jsonobject忽略字段
  • 现金支票应记入什么账户
  • 资产负债表中的应收账款应根据什么填列
  • 利息资本化怎么计算
  • websocket基于http
  • 矿产资源补偿费是什么
  • wordpress mobile themes
  • 金融企业往来支出是一级科目吗
  • 捐赠合同模板
  • 印花税怎么计算公式
  • 小微企业认定需要哪些资料
  • 一次还本付息和分期付息的计算
  • sqlldr并发
  • 固定资产清理是资产类的备抵科目吗
  • 工会经费不够
  • xp系统控制面板在哪里打开
  • 通过注册表设置u盘启动
  • Win10系统怎么删除管理员权限
  • 手动去除扁桃体结石教程
  • 桌面快捷方式不显示图标怎么办
  • windowsxpdos命令
  • linux操作系统版本有哪些
  • windows7无法安装
  • linux tar命令安装
  • 细说javascript
  • 如何检测ip地址是否被占用
  • 世界坐标转换成屏幕坐标
  • #vr#
  • android下载文件保存到本地
  • jquery实现ajax加载超时提示的方法
  • js基础
  • 南京税务局 局长
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设