达梦(DM) SQL调优

简介: 【1月更文挑战第2天】达梦(DM) SQL调优

说到SQL调优,那可以说是开发者日常开发过程中经常会遇到的问题,不管你使用的是开源Mysql数据库,还是云原生数据库,或者是其他数据库,SQL调优的问题都是一个长期且久远的事。由于最近的项目使用的是DM数据库,那么这里就基于DM数据库SQL调优来浅谈一下吧。

SQL 调优

SQL 调优作为数据库性能调优中的最后一个环节,对查询性能产生着直接的影响。SQL 调优的整体目标简单的说就是使用最优的执行计划,这意味着 IO 以及 CPU 代价最小,来达到最大的查询性能。

SQL调优方案

对于SQL调优,常见的方案有优化SQL,增加索引,优化表结构等,这里主要讲述一下日常写SQL过程中可能会忽略的SQL调优细节。

避免OR子句

大家都知道,通常情况下一个 OR 子句不能利用上索引则会使用全表扫描造成效率低下,所以应尽量避免使用OR子句,但是有时候可能不得不用OR子句,这个时候可以用以下替代方案。分析OR子句,通常是针对一列进行过滤,那么可以使用IN,比如

select*from edu_face_train_apply_person where person_id=7or person_id=8;

改写成

select*from edu_face_train_apply_person where person_id in(7,8);

SELECT 项避免‘*’

通常情况下,SQL查询往往并不需要得到表中所有列,那么此时使用SELECT *这种写法将让执行器背上沉重的负荷。因为每一列的数据不得不自下往上层层向上传递,这样对于磁盘IO的损耗是巨大的。这个时候就需要开发者了解表结构和业务需求,小心地选择需要的列并一一给出名称,避免直接用 SELECT *。这样可以尽可能的提高查询效率。

避免重复索引

可以说数据库添加索引在一定程度上可以提高数据库SQL的查询效率,但是并不是说索引就建的越多越好,大量重复的索引并不利于提高查询效率的同时,如果表的增删改操作频繁,那么对于索引的维护同样也是耗时巨大的,因此索引的创建要适宜。

COUNT(*)统计行数

使用COUNT(*)统计行数,如果没有过滤条件,DM 优化器会直接读取相关索引中存储的行数信息并进行内部修正后,迅速地给出最终结果而避免对实际数据的读取。而COUNT(列名)会对数据进行读操作,执行效率远低于 COUNT(*)。在有过滤条件时,COUNT(*)执行效率依然优于其他。另外,COUNT(*)会将 NULL 值计算在内而 COUNT(列名)是不包含 NULL 值的,因此需要注意应用场景决定是否可以使用 COUNT(*)。

UNION 和 UNION ALL

UNION 和 UNIONALL 的区别是前者会过滤掉值完全相同的数据,因此如果应用场景并不关心重复数据或者不可能出现重复,那么 UNION ALL 无疑优于 UNION。

当然除了以上这些SQL优化的方案,比如SQL查询中减少表关联等同样可以提高查询效率。

最后

关于达梦数据库更多查询优化方案以及提高查询效率相关分析说明可以参考达梦数据库官方文档:查询优化

相关文章
|
4月前
|
SQL Oracle 关系型数据库
Oracle SQL:了解执行计划和性能调优
Oracle SQL:了解执行计划和性能调优
125 1
|
5月前
|
存储 SQL 关系型数据库
【MySQL调优】如何进行MySQL调优?从参数、数据建模、索引、SQL语句等方向,三万字详细解读MySQL的性能优化方案(2024版)
MySQL调优主要分为三个步骤:监控报警、排查慢SQL、MySQL调优。 排查慢SQL:开启慢查询日志 、找出最慢的几条SQL、分析查询计划 。 MySQL调优: 基础优化:缓存优化、硬件优化、参数优化、定期清理垃圾、使用合适的存储引擎、读写分离、分库分表; 表设计优化:数据类型优化、冷热数据分表等。 索引优化:考虑索引失效的11个场景、遵循索引设计原则、连接查询优化、排序优化、深分页查询优化、覆盖索引、索引下推、用普通索引等。 SQL优化。
852 15
【MySQL调优】如何进行MySQL调优?从参数、数据建模、索引、SQL语句等方向,三万字详细解读MySQL的性能优化方案(2024版)
|
5月前
|
SQL 分布式计算 数据库
SQL调优总结
数据库表的规范化和反规范化设计,设计合适的字段数据类型……
57 8
|
6月前
|
Java XML Maven
跨越时代的飞跃:Struts 2 升级秘籍——从旧版本无缝迁移到最新版,焕发应用新生!
【8月更文挑战第31天】随着软件技术的发展,Struts 2 框架也在不断更新。本文通过具体案例指导开发者如何从旧版平滑升级到 Struts 2.6.x。首先更新 `pom.xml` 中的依赖版本,并执行 `mvn clean install`。接着检查 `struts.xml` 配置,确保符合新版本要求,调整包扫描器等设置。审查 Action 类及其注解,检查配置文件中的弃用项及插件。更新自定义拦截器实现,并验证日志配置。最后,通过一系列测试确保升级后的系统正常运行。通过这些步骤,可以顺利完成 Struts 2 的版本升级,提升应用的安全性和性能。
1229 0
|
6月前
|
Java 开发者 前端开发
Struts 2、Spring MVC、Play Framework 上演巅峰之战,Web 开发的未来何去何从?
【8月更文挑战第31天】在Web应用开发中,Struts 2框架因强大功能和灵活配置备受青睐,但开发者常遇配置错误、类型转换失败、标签属性设置不当及异常处理等问题。本文通过实例解析常见难题与解决方案,如配置文件中遗漏`result`元素致页面跳转失败、日期格式不匹配需自定义转换器、`<s:checkbox>`标签缺少`label`属性致显示不全及Action中未捕获异常影响用户体验等,助您有效应对挑战。
123 0
|
6月前
|
SQL 监控 关系型数据库
SQL性能监控与调优工具的神奇之处:如何用最佳实践选择最适合你的那一个,让你的数据库飞起来?
【8月更文挑战第31天】在现代软件开发中,数据库性能监控与调优对应用稳定性至关重要。本文对比了数据库内置工具、第三方工具及云服务工具等几种常用SQL性能监控与调优工具,并通过示例代码展示了如何利用MySQL的EXPLAIN功能分析查询性能。选择最适合的工具需综合考虑功能需求、数据库类型及成本预算等因素。遵循了解工具功能、试用工具及定期维护工具等最佳实践,可帮助开发者更高效地管理和优化数据库性能,迎接未来软件开发中的挑战与机遇。
82 0
|
6月前
|
SQL 关系型数据库 MySQL
SQL性能调优的神奇之处:如何用优化技巧让你的数据库查询飞起来,实现秒级响应?
【8月更文挑战第31天】在现代软件开发中,数据库性能至关重要。本文通过一个实战案例,展示了从慢查询到秒级响应的全过程。通过对查询的详细分析与优化,包括创建索引、改进查询语句及数据类型选择等措施,最终显著提升了性能。文章还提供了示例代码及最佳实践建议,帮助读者掌握SQL性能调优的核心技巧。
292 0
|
7月前
|
机器学习/深度学习 SQL 自然语言处理
现代深度学习框架构建问题之深度学习通用架构的定义如何解决
现代深度学习框架构建问题之深度学习通用架构的定义如何解决
67 3
|
7月前
|
SQL 运维 监控
MSSQL性能调优实战技巧:索引优化、SQL查询优化与并发控制策略
在Microsoft SQL Server(MSSQL)的运维过程中,性能调优是确保数据库高效运行、满足业务需求的关键环节
|
7月前
|
SQL 数据库 开发者
MSSQL性能调优实战技巧:索引优化、SQL语句微调与并发控制策略
在Microsoft SQL Server(MSSQL)的管理与优化中,性能调优是一项复杂但至关重要的任务