热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

个人笔记分析程序变慢原因

原因:联查了有大表改进:1联查字段加索引2排序字段加索引3加统计表4冷热数据5in改为exists2018726发现变慢原因ÿ

原因:

联查了有大表

改进:

1 联查字段加索引

2 排序字段加索引

3 加统计表

4 冷热数据

5 in改为exists

2018 7 /26

发现变慢原因:

1 联查表是大表,大表不能用in,只能用exists

2 提前从in 里面筛选出在主表bu'm不满足条件的数据

INQ里面  

如果有个从表很大并且 需要筛选  又和主表有关联关系,并且不想读取从表信息。

源代码:li包含了所有

ll = coupon.Select(y => y.Cid).ToList();var model =act.Where(o => ll.Contains(o.ID)&&Type=2);

因为 coupon超级大,运行超级慢

改代码:

ll = coupon.where(act.Any(o => o.type=2).Select(y => y.Cid).ToList();var model = act.Where(o => ll.Contains(o.ID));

把条件提前加入筛选集合里面,运行很快

 

加索引,主要是where 或者orderby自己认为标准: 

1 联查大表的字段,大表的字段加索引

2 排序的字段

3sum的字段

3 不是所有条件字段加索引

 

 时间筛选不能直接用大于小于,用函数来写

SELECT [id],[order_no],[trade_no]FROM [orders] WHERE add_time<&#39;2018-07-31 15:32:13&#39; AND add_time>&#39;2018-07-15 15:32:13&#39;

执行时间

改为


SELECT [id],[order_no],[trade_no]FROM [orders] WHERE datediff(dd,add_time,&#39;2018-07-31&#39;) >&#61; 0 AND datediff(dd, &#39;2018-07-01&#39;, add_time )>&#61; 0

还是很慢

加一张表联查&#xff0c;做为中间表&#xff0c;还是很慢&#xff0c;

SELECT [id],[order_no],[trade_no]from [orders] join [orderDateDiff]on [dt_orders].id&#61;[orderDateDiff].order_idwhere [orderDateDiff].[datediff]<15

 


推荐阅读
  • 中科院学位论文排版指南
    随着毕业季的到来,许多即将毕业的学生开始撰写学位论文。本文介绍了使用LaTeX排版学位论文的方法,特别是针对中国科学院大学研究生学位论文撰写规范指导意见的最新要求。LaTeX以其精确的控制和美观的排版效果成为许多学者的首选。 ... [详细]
  • 2018-2019学年第六周《Java数据结构与算法》学习总结
    本文总结了2018-2019学年第六周在《Java数据结构与算法》课程中的学习内容,重点介绍了非线性数据结构——树的相关知识及其应用。 ... [详细]
  • 本文介绍如何使用MFC和ADO技术调用SQL Server中的存储过程,以查询指定小区在特定时间段内的通话统计数据。通过用户界面选择小区ID、开始时间和结束时间,系统将计算并展示小时级的通话量、拥塞率及半速率通话比例。 ... [详细]
  • 本文介绍了如何利用Python的高精度计算库mpmath实现π的100种不同计算方法。通过设置更高的精度和优化的数学函数,这些方法能够提供极其精确的结果。 ... [详细]
  • 采用IKE方式建立IPsec安全隧道
    一、【组网和实验环境】按如上的接口ip先作配置,再作ipsec的相关配置,配置文本见文章最后本文实验采用的交换机是H3C模拟器,下载地址如 ... [详细]
  • 本教程详细介绍了如何使用 TensorFlow 2.0 构建和训练多层感知机(MLP)网络,涵盖回归和分类任务。通过具体示例和代码实现,帮助初学者快速掌握 TensorFlow 的核心概念和操作。 ... [详细]
  • 本文介绍了如何利用Python进行批量图片尺寸调整,包括放大和等比例缩放。文中提供了详细的代码示例,并解释了每个步骤的具体实现方法。 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • Oracle中NULL、空字符串和空格的处理与区别
    本文探讨了在Oracle数据库中使用NULL、空字符串('')和空格('_')时可能遇到的问题及解决方案。重点解释了它们之间的区别,以及在查询和函数中的行为。 ... [详细]
  • 本文探讨了如何通过预处理器开关选择不同的类实现,并解决在特定情况下遇到的链接器错误。 ... [详细]
  • LeetCode 690:计算员工的重要性评分
    在解决LeetCode第690题时,我记录了详细的解题思路和方法。该问题要求根据员工的ID计算其重要性评分,包括直接和间接下属的重要性。本文将深入探讨如何使用哈希表(Map)来高效地实现这一目标。 ... [详细]
  • 深入解析SpringMVC核心组件:DispatcherServlet的工作原理
    本文详细探讨了SpringMVC的核心组件——DispatcherServlet的运作机制,旨在帮助有一定Java和Spring基础的开发人员理解HTTP请求是如何被映射到Controller并执行的。文章将解答以下问题:1. HTTP请求如何映射到Controller;2. Controller是如何被执行的。 ... [详细]
  • 本文将探讨2015年RCTF竞赛中的一道PWN题目——shaxian,重点分析其利用Fastbin和堆溢出的技巧。通过详细解析代码流程和漏洞利用过程,帮助读者理解此类题目的破解方法。 ... [详细]
  • 本文介绍两道有趣的编程问题:一是寻找给定数字n的连续数字序列及其个数,二是模拟一个翻杯子的游戏。同时附带一道智商题供读者思考。 ... [详细]
  • 版本控制工具——Git常用操作(下)
    本文由云+社区发表作者:工程师小熊摘要:上一集我们一起入门学习了git的基本概念和git常用的操作,包括提交和同步代码、使用分支、出现代码冲突的解决办法、紧急保存现场和恢复 ... [详细]
author-avatar
syjs10
这个家伙很懒
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有