fastapi中的ORM

简单说,ORM 就像你和一个外国厨师之间的"翻译官"。

ORM 全称是 Object-Relational Mapping(对象关系映射)。

它会把你写的 Python 对象(类和实例),自动翻译成数据库能听懂的 SQL 语句,去操作数据表。

FastAPI 本身不内置 ORM,但它通常会搭配 SQLAlchemy、Tortoise-ORM 等 ORM 库一起用,来实现上面这种翻译工作。

通俗比喻:去餐厅点菜

想象你去一家西餐厅:

你(程序员):想说"来一份牛排",但你只会说 Python。

数据库(厨师):只懂 SQL(数据库语言),听不懂 Python。

ORM(服务员):接过你的 Python 需求,转身对厨房喊:"SELECT * FROM menu WHERE name='牛排'",再把做好的牛排端给你。

你不用关心厨房怎么运作,说"人话"就能拿结果------这就是 ORM 的精髓。

ORM 在 FastAPI 中的具体作用

  1. 用 Python 类代替 SQL 语句

没有 ORM,你要手写长长的字符串:

复制代码
INSERT INTO users (name, email) VALUES ('小明', 'xiao@email.com');

有了 ORM,你只需操作 Python 对象:

复制代码
new_user = User(name="小明", email="xiao@email.com")   # 建一个用户对象
db.add(new_user)   # 交给数据库,ORM 自动生成 SQL 插入

对程序员来说,这就是"用操作对象的思维来操作数据库",思维更连贯。

  1. 防止 SQL 注入攻击

如果你手动拼接 SQL,比如:

复制代码
query = f"SELECT * FROM users WHERE id = {user_input}"
  1. 换数据库更容易

假如项目原本用 SQLite,后来要换成 PostgreSQL。用 ORM 的话,基本只改一个连接地址,代码一行不用动。因为 ORM 帮你屏蔽了不同数据库的方言差异。

  1. 和 FastAPI 的类型系统完美配合

FastAPI 强在 Pydantic 模型(用于请求/响应数据校验)。而 ORM 负责定义数据库表模型。这两者可以清晰分工:

Pydantic 模型 → 定义接口长什么样(给前端看)

ORM 模型 → 定义数据库表长什么样(存数据)

两者结构类似,真正实现了"数据验证"和"数据存储"的解耦。这是 FastAPI 开发中最经典的模式。

总结一句话

ORM 让你能用写 Python 类的方式操作数据库,把又臭又长的 SQL 代码变成优雅的对象操作,更安全、好维护,且天生适合 FastAPI 的现代开发风格。

相关推荐
CaffeinePro2 天前
Pydantic深度使用:数据校验、枚举、ORM映射
后端·fastapi
倔强的石头_2 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab3 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence3 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神3 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据4 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_4 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡4 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧4 天前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon4 天前
SQL学习指南——视图
数据库·sql