”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 从开发人员到审阅者:初级开发人员审阅数据库查询的清单

从开发人员到审阅者:初级开发人员审阅数据库查询的清单

发布于2024-11-08
浏览:690

作为开发人员,提供高质量的代码至关重要,这些代码不仅具有功能性,而且还针对性能进行了优化。在开发人员领域的三年里,我从一名实践开发人员转变为审阅者角色。我在审核过程中关注的关键领域之一是数据库查询优化。

为什么关注数据库查询?
数据库查询可以显着影响应用程序的性能。编写得好的查询可以有效地获取数据,而编写得不好的查询可能会导致数据库命中过多,从而降低整个系统的速度。作为初级开发人员,您可能想知道如何在代码审查期间评估这些查询的性能。这是我的首选清单。

检查数据库查询的清单

  1. 数据库点击次数:

    • 第一步是确定一段代码命中了多少数据库。对数据库的每次命中都会增加延迟,因此较少的命中通常意味着更好的性能。
    • 专业提示:使用Django的connection.queries和reset_queries来跟踪执行的查询数量以及每个查询所花费的时间。例如: From Developer to Reviewer: A Junior Developer
  2. 减少点击次数:

    • 一旦知道点击次数,下一步就是看看是否可以减少点击次数。减少数据库命中通常可以通过优化查询或将多个查询合并为一个来实现。
    • 关键技术:
      • 延迟加载与急切加载:了解何时评估查询。延迟加载将查询延迟到真正需要数据时才进行,但这可能会导致 N 1 查询问题。预加载,使用 select_lated 或 prefetch_lated,在单个查询中获取相关对象,从而减少命中总数。
      • 联接:如果需要相关表中的数据,请考虑使用联接查询。 Django 的 select_lated (对于外键关系)和 prefetch_lated (对于多对多或反向外键关系)是你的朋友。
  3. 避免冗余查询:

    • 检查冗余查询,即同一查询被执行多次。这通常可以通过缓存结果或重构代码来避免。
    • 示例:不要在循环内查询相关对象,而是在循环之前获取所有相关对象一次。
  4. 内存注意事项:

    • 虽然减少数据库命中很重要,但也要考虑内存使用情况。将大量数据集加载到内存中可能会导致应用程序速度减慢或崩溃。旨在仅提取您需要的记录/数据。

结论
检查数据库查询的性能是一项随着时间和经验的增长而发展的技能。作为初级开发人员,首先要关注基础知识 - 计算数据库命中率并找到减少命中率的方法。在此过程中,connection.queries、reset_queries 和 Django 的 ORM 功能等工具非常有用。随着时间的推移,您将形成一种仅通过查看代码即可发现性能问题的直觉。在此之前,请依靠此处讨论的工具和技术来指导您。

其他提示:

  1. 了解执行计划: 通过了解 ORM 查询生成的 SQL 执行计划来更深入地了解。 SQL 中的 EXPLAIN 等工具可以帮助您了解数据库引擎如何执行查询,从而深入了解潜在的优化。

给新手开发人员的提示:
要开始审查其他人的代码,您不需要了解系统的每个流程。首先检查代码质量和优化等小事情。从第一步开始,专注于基础知识,最终,您将成为一名出色的审稿人。
另外,在审阅时,请尽量保持礼貌并在评论中提供帮助,而不是傲慢。请记住,目标是改进代码并帮助您的团队,而不仅仅是指出错误。

版本声明 本文转载于:https://dev.to/aman-giri/from-developer-to-reviewer-a-junior-developers-checklist-for-reviewing-database-queries-4kdm?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • eval()vs. ast.literal_eval():对于用户输入,哪个Python函数更安全?
    eval()vs. ast.literal_eval():对于用户输入,哪个Python函数更安全?
    称量()和ast.literal_eval()中的Python Security 在使用用户输入时,必须优先确保安全性。强大的Python功能Eval()通常是作为潜在解决方案而出现的,但担心其潜在风险。本文深入研究了eval()和ast.literal_eval()之间的差异,突出显示其安全性含义...
    编程 发布于2025-05-05
  • Java中假唤醒真的会发生吗?
    Java中假唤醒真的会发生吗?
    在Java中的浪费唤醒:真实性或神话?在Java同步中伪装唤醒的概念已经是讨论的主题。尽管存在这种行为的潜力,但问题仍然存在:它们实际上是在实践中发生的吗? Linux的唤醒机制根据Wikipedia关于伪造唤醒的文章,linux实现了pthread_cond_wait()功能的Linux实现,利用...
    编程 发布于2025-05-05
  • 如何有效地转换PHP中的时区?
    如何有效地转换PHP中的时区?
    在PHP 利用dateTime对象和functions DateTime对象及其相应的功能别名为时区转换提供方便的方法。例如: //定义用户的时区 date_default_timezone_set('欧洲/伦敦'); //创建DateTime对象 $ dateTime = ne...
    编程 发布于2025-05-05
  • 如何正确使用与PDO参数的查询一样?
    如何正确使用与PDO参数的查询一样?
    在pdo 中使用类似QUERIES在PDO中的Queries时,您可能会遇到类似疑问中描述的问题:此查询也可能不会返回结果,即使$ var1和$ var2包含有效的搜索词。错误在于不正确包含%符号。通过将变量包含在$ params数组中的%符号中,您确保将%字符正确替换到查询中。没有此修改,PDO...
    编程 发布于2025-05-05
  • 您如何在Laravel Blade模板中定义变量?
    您如何在Laravel Blade模板中定义变量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配变量对于存储以后使用的数据至关重要。在使用“ {{}}”分配变量的同时,它可能并不总是最优雅的解决方案。幸运的是,Blade通过@php Directive提供了更优雅的方法: $ old_section =“...
    编程 发布于2025-05-05
  • 在细胞编辑后,如何维护自定义的JTable细胞渲染?
    在细胞编辑后,如何维护自定义的JTable细胞渲染?
    在JTable中维护jtable单元格渲染后,在JTable中,在JTable中实现自定义单元格渲染和编辑功能可以增强用户体验。但是,至关重要的是要确保即使在编辑操作后也保留所需的格式。在设置用于格式化“价格”列的“价格”列,用户遇到的数字格式丢失的“价格”列的“价格”之后,问题在设置自定义单元格...
    编程 发布于2025-05-05
  • 为什么我会收到MySQL错误#1089:错误的前缀密钥?
    为什么我会收到MySQL错误#1089:错误的前缀密钥?
    mySQL错误#1089:错误的前缀键错误descript [#1089-不正确的前缀键在尝试在表中创建一个prefix键时会出现。前缀键旨在索引字符串列的特定前缀长度长度,以便更快地搜索这些前缀。理解prefix keys `这将在整个Movie_ID列上创建标准主键。主密钥对于唯一识别...
    编程 发布于2025-05-05
  • 在Java中使用for-to-loop和迭代器进行收集遍历之间是否存在性能差异?
    在Java中使用for-to-loop和迭代器进行收集遍历之间是否存在性能差异?
    For Each Loop vs. Iterator: Efficiency in Collection TraversalIntroductionWhen traversing a collection in Java, the choice arises between using a for-...
    编程 发布于2025-05-05
  • MySQL中如何高效地根据两个条件INSERT或UPDATE行?
    MySQL中如何高效地根据两个条件INSERT或UPDATE行?
    在两个条件下插入或更新或更新 solution:的答案在于mysql的插入中...在重复键更新语法上。如果不存在匹配行或更新现有行,则此功能强大的功能可以通过插入新行来进行有效的数据操作。如果违反了唯一的密钥约束。实现所需的行为,该表必须具有唯一的键定义(在这种情况下为'名称'...
    编程 发布于2025-05-05
  • \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    答案: 在大多数现代编译器中,while(1)和(1)和(;;)之间没有性能差异。编译器: perl: 1 输入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    编程 发布于2025-05-05
  • 表单刷新后如何防止重复提交?
    表单刷新后如何防止重复提交?
    在Web开发中预防重复提交 在表格提交后刷新页面时,遇到重复提交的问题是常见的。要解决这个问题,请考虑以下方法: 想象一下具有这样的代码段,看起来像这样的代码段:)){ //数据库操作... 回声“操作完成”; 死(); } ?> ...
    编程 发布于2025-05-05
  • 如何从2D数组中提取元素?使用另一数组的索引
    如何从2D数组中提取元素?使用另一数组的索引
    Using NumPy Array as Indices for the 2nd Dimension of Another ArrayTo extract specific elements from a 2D array based on indices provided by a second ...
    编程 发布于2025-05-05
  • 如何使用Depimal.parse()中的指数表示法中的数字?
    如何使用Depimal.parse()中的指数表示法中的数字?
    在尝试使用Decimal.parse(“ 1.2345e-02”中的指数符号表示法表示的字符串时,您可能会遇到错误。这是因为默认解析方法无法识别指数符号。 成功解析这样的字符串,您需要明确指定它代表浮点数。您可以使用numbersTyles.Float样式进行此操作,如下所示:[&& && && ...
    编程 发布于2025-05-05
  • Java开发者如何保护数据库凭证免受反编译?
    Java开发者如何保护数据库凭证免受反编译?
    在java 在单独的配置文件保护数据库凭证的最有效方法中存储凭据是将它们存储在单独的配置文件中。该文件可以在运行时加载,从而使登录数据从编译的二进制文件中远离。使用prevereness class import java.util.prefs.preferences; 公共类示例{ 首选项...
    编程 发布于2025-05-05
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    在使用GO MOD时,在GO MOD 中克服模块路径差异时,可能会遇到冲突,其中可能会遇到一个冲突,其中3派对软件包将另一个带有导入套件的path package the Imptioned package the Imptioned package the Imported tocted pac...
    编程 发布于2025-05-05

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3