1. ORM 与关系型数据库(MySQL、PostgreSQL) 的使用

  • SQL 语句编写(JOIN、GROUP BY、索引使用、事务控制)与 ORM 映射(如 Sequelize、TypeORM、Hibernate)之间的差异会让新手非常纠结;尤其是理解事务隔离级别、死锁、索引优化等概念,需要不断摸索才能明白。

摘要

在企业级后端开发中,ORM 框架(如 Sequelize、TypeORM、Hibernate)几乎是标配,它们大大减少了 SQL 编写的工作量。但问题在于:当遇到复杂业务逻辑(JOIN、GROUP BY、事务、索引优化等)时,ORM 的抽象层与数据库原生语法的差异会导致开发者踩坑。本文将结合 MySQL、PostgreSQL 的场景,详细解析 ORM 使用中常见问题与解决思路。

文章目录

  • 1. ORM 与关系型数据库(MySQL、PostgreSQL) 的使用
    • 摘要
    • 1 开发场景介绍
    • 2 开发环境
    • 3 ORM 与 SQL 差异
      • 3.1 JOIN 与多表查询
    • 4 事务控制与隔离级别
    • 5 死锁案例
    • 6 索引优化与 ORM 限制
    • 7 实践经验与建议
    • 8 总结


1 开发场景介绍

在一个金融级后台项目中,团队使用 TypeORM + PostgreSQL 作为主要数据访问层。由于业务涉及资金流水、用户账户管理,要求高并发下的事务一致性。然而在使用 ORM 时,以下问题频繁出现:

ORM 自动生成的 SQL 语句无法满足复杂 JOIN 需求,导致性能下降。
ORM 封装的事务隔离逻辑与数据库原生隔离级别理解不一致,容易触发死锁。
ORM 自动创建索引策略与 DBA 的手动优化存在冲突。


2 开发环境

技术栈版本说明
Node.js18.x后端运行环境
TypeORM0.3.xORM 框架
PostgreSQL15.x关系型数据库
Sequelize6.x对比 ORM
Hibernate5.xJava 场景常见 ORM
Docker24.x容器化环境

3 ORM 与 SQL 差异

3.1 JOIN 与多表查询

手写 SQL:

SELECT u.id, u.name, SUM(o.amount) AS total_amount
FROM users u
JOIN orders o ON u.id = o.user_id
GROUP BY u.id;

TypeORM 查询:

const result = await userRepository.createQueryBuilder("u").leftJoinAndSelect("u.orders", "o").select("u.id").addSelect("u.name").addSelect("SUM(o.amount)", "total_amount").groupBy("u.id").getRawMany();

ORM 虽然提供了类似写法,但复杂度更高,也更难优化。


4 事务控制与隔离级别

事务控制是新手最困惑的部分。MySQL 与 PostgreSQL 支持 四种隔离级别

READ UNCOMMITTED
READ COMMITTED
REPEATABLE READ
SERIALIZABLE
  • READ COMMITTED:解决脏读,但仍可能出现不可重复读。
  • REPEATABLE READ:PostgreSQL 默认,避免不可重复读,但会产生幻读。
  • SERIALIZABLE:最严格,但可能触发死锁。

在 TypeORM 中,事务管理依赖 queryRunner,但如果不了解底层数据库的隔离级别,ORM 封装可能误导开发者。


5 死锁案例

当两个事务并发执行时,可能出现以下典型死锁:

  1. 事务 A 锁住用户表,等待订单表;
  2. 事务 B 锁住订单表,等待用户表;
  3. 数据库检测到循环等待,强制回滚其中一个事务。

解决方案

  • 遵循固定的锁顺序。
  • 尽量缩短事务执行时间。
  • 使用数据库原生的 NOWAITSKIP LOCKED 来避免阻塞。

6 索引优化与 ORM 限制

ORM 会根据实体定义自动生成索引,但并不一定合理。例如:

场景ORM 默认行为最佳实践
外键字段自动加索引保留,但需人工验证是否命中查询条件
多字段组合查询不会生成组合索引DBA 手工创建复合索引
频繁排序字段无优化人工添加 BTREE 索引

7 实践经验与建议

  1. 不要完全依赖 ORM:复杂业务场景下,手写 SQL 结合 ORM 更高效。
  2. 理解数据库原理:事务、锁、索引这些核心知识不可绕过。
  3. 监控 SQL 性能:开启数据库日志,分析 ORM 自动生成 SQL 的执行计划。
  4. 保持 ORM 与 DBA 的协作:在索引与事务上多沟通,避免性能问题。

后端bug


8 总结

ORM 框架提升了开发效率,但在涉及 事务隔离、死锁、索引优化 时,开发者必须掌握数据库底层原理。否则,看似优雅的 ORM 层抽象,最终会演变为难以定位的性能瓶颈。

一句话总结
ORM 是开发者的好帮手,但只有结合 SQL 与数据库原理,才能真正发挥威力。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/98306.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/98306.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/98306.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JavaScript 创建型设计模式详解

1. 单例模式1.1. 使用场景在前端开发中,全局状态管理、配置信息、数据库连接等往往需要在应用中只存在一个实例,避免多次实例化带来的数据不一致性。例如,在一个前端应用中,全局的 loading 状态通常需要一个单例模式来确保其唯一性…

k8s除了主server服务器可正常使用kubectl命令,其他节点不能使用原因,以及如何在其他k8s节点正常使用kubectl命令??

kubectl 并不是“只能”在主节点(Control Plane Node)使用,而是因为它需要访问 Kubernetes 的 kube-apiserver,而 kube-apiserver 通常只在主节点上运行并监听内部网络。简单来说kubectl 需要连接 kube-apiserver!&…

Custom SRP - Complex Maps

https://catlikecoding.com/unity/tutorials/custom-srp/complex-maps/1 创建材质球我们的材质已经支持光照,并且支持 Albedo 和 Emission 贴图.创建材质球,并应用下面的电路板的图分别作为 albedo emission设置材质球的金属度为 1 , 光滑度为 0.952 Mask Map在 albedo 图上的不…

repo 学习教程

你现在会用 git 了,接下来学 repo(Google 推出来的多仓库管理工具),其实就是在 Git 的基础上做了一层封装,方便同时管理很多 Git 仓库。像 Android 源码、Rockchip 全套 SDK 都是靠 repo 来拉取和管理的。 我给你分几个…

[SWERC 2020] Safe Distance题解

[SWERC 2020] Safe Distance 题意 给定 NNN 个点与一个坐标 (X,Y)(X,Y)(X,Y),求从点 (0,0)(0,0)(0,0) 到点 (X,Y)(X,Y)(X,Y) 规划一条路线,不能走出 (0,0)(0,0)(0,0) 与 (X,Y)(X,Y)(X,Y) 间形成的矩形,使得通过这条路线时距离最近的点的距离…

Rewind-你人生的搜索引擎

本文转载自:Rewind-你人生的搜索引擎 - Hello123工具导航 ** 一、🔍 Rewind 是什么?你的数字记忆增强神器 Rewind 是一款人工智能驱动的个人记忆助手,就像为你配备了一个「数字第二大脑」。它能自动记录、保存并索引你在电脑和手…

开发小点 - 存

开发小点 1.Req注解 EqualsAndHashCode(callSuper true) Data public class BillSituationReq extends BillQueryReq {/*** Whether to display the ring ratio, default is not displayed*/ApiModelProperty("Whether to Display YoY Comparison")private Boolean …

只会npm install?这5个隐藏技巧让你效率翻倍!

原文链接:https://mp.weixin.qq.com/s/nijxVWj-E5U08DX2fl3vgg最近有个刚学前端的小伙伴问我:“为什么我的node_modules这么大?为什么别人装依赖那么快?npx到底是啥玩意儿?” 相信不少人都跟他一样,对npm的…

(二).net面试(static)

文章目录项目地址一、基础501.1 new keyword1.2 static class vs. static method1. static class2. static method3. static constructor 静态构造函数4. 静态成员的生命周期1.3 LinQ1.what is LinQ2. List<T>、IEnumerable<T>、IQueryable<T>3. 在数据库里用…

docker,本地目录挂载

理解Docker本地目录挂载的基本概念Docker本地目录挂载允许容器与宿主机共享文件或目录&#xff0c;实现数据持久化和实时交互。挂载方式分为bind mount和volume两种&#xff0c;前者直接映射宿主机路径&#xff0c;后者由Docker管理存储路径。本地目录挂载的核心方法bind mount…

IO多路复用相关知识

select、poll、epoll 在传入的性能差异是不是体现在&#xff0c;当有新的连接过来&#xff0c;此时需要将新的fd传入到内核中&#xff0c;但是poll/select需要出入整个数组&#xff0c;而epoll方式只需要出入单个fd&#xff1f; 1. select/poll 的情况它们没有内核中“长期保存…

【CF】Day139——杂题 (绝对值变换 | 异或 + 二分 | 随机数据 + 图论)

B. Meeting on the Line题目&#xff1a;思路&#xff1a;数形结合首先考虑如果没有 t 的影响该怎么写显然我们就是让最大时间最小化&#xff0c;那么显然选择最左端点和最右端点的中间值即可&#xff0c;即 (mi mx) / 2&#xff0c;那么现在有了 t 该怎么办我们不妨考虑拆开绝…

在 Ubuntu 上安装和配置 PostgreSQL 实录

一、查看ubuntu版本 lsb_release -a postgresq尽量安装在新的稳定版本的ubuntu上 二、安装postgresql 2.1 直接安装 sudo apt install postgresql 结果如下 2.2 使用PPA源安装 Ubuntu官方源提供了PostgreSQL的PPA(Personal Package Archive),通过PPA源安装可以确保获取…

WebGIS三维可视化 + 数据驱动:智慧煤仓监控系统如何破解煤炭仓储行业痛点

目录 一、项目背景&#xff1a;煤炭仓储管理的痛点与转型需求 二、建设意义&#xff1a;从 “被动管理” 到 “主动掌控” 的价值跃迁 三、项目核心&#xff1a;技术架构与核心目标的深度融合 四、数据与技术&#xff1a;系统稳定运行的 “双支柱” &#xff08;一&#x…

使用 Spring Security 实现 OAuth2:一步一步的操作指南

前言 OAuth 是一种授权框架&#xff0c;用于创建权限策略&#xff0c;并允许应用程序对用户在 HTTP 服务&#xff08;如 GitHub 和 Google&#xff09;上的账户进行有限访问。它的工作原理是允许用户授权第三方应用访问他们的数据&#xff0c;而无需分享他们的凭证。本文将指导…

VMware共享文件夹设置

启用共享文件夹 编辑虚拟机设置-选项-共享文件夹&#xff0c;上面的选项选择启用下面点击添加一个路径&#xff0c;跟着向导走 设置共享文件夹在主机的路径&#xff0c;和文件夹名称添加完成后可以点击这个共享文件夹条目&#xff0c;查看属性虚拟机里安装vm-tools sudo apt up…

华为云昇腾云服务

华为云&#xff0c;一切皆服务共建智能世界云底座面向未来的智能世界&#xff0c;数字化是企业发展的必由之路。数字化成功的关键是以云原生的思维践行云原生&#xff0c;全数字化、全云化、AI驱动&#xff0c;一切皆服务。华为云将持续创新&#xff0c;携手客户、合作伙伴和开…

Axum 最佳实践:如何构建优雅的 Rust 错误处理系统?(三)

引言 作为开发者&#xff0c;我们都经历过这样的场景&#xff1a;项目上线后&#xff0c;你打开日志监控&#xff0c;铺天盖地的 500 Internal Server Error 扑面而来。这些错误像个黑洞&#xff0c;吞噬着你的调试时间&#xff0c;你甚至不知道它们是从数据库查询失败&#x…

MySQL高可用方案解析:从复制到云原生

MySQL 的高可用 (High Availability, HA) 方案旨在确保数据库服务在硬件故障、软件崩溃、网络中断或计划维护时仍能持续可用&#xff0c;最小化停机时间&#xff08;通常目标为 99.9% 至 99.999% 可用性&#xff09;。以下是 MySQL 领域成熟且广泛应用的几种主流高可用方案&…

腾讯云语音接口实现会议系统

1.前言 在现代企业协作环境中&#xff0c;高效的会议管理是提升团队生产力的关键。本文将深入解析一个完整的会议管理系统&#xff0c;涵盖从会议创建到总结生成的完整生命周期。该系统构建一个基于AI技术的智能会议系统&#xff0c;实现会议全流程的智能化管理&#xff0c;包括…