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 的现代开发风格。

相关推荐
南境十里·墨染春水5 小时前
linux学习进展 mysql数据库
linux·数据库·学习
whn19776 小时前
达梦存储过程执行时,sqllog日志中信息记录情况
数据库
2301_809204706 小时前
如何用 Babel 将最新的 JS 特性转译为旧版浏览器兼容代码
jvm·数据库·python
胡楚昊6 小时前
BUU WEB之旅(1)
java·数据库·mybatis
夏恪6 小时前
golang如何实现滚动更新方案_golang滚动更新方案实现实战
jvm·数据库·python
2301_818008446 小时前
CSS如何让响应式图片在容器内居中_利用background-position
jvm·数据库·python
weixin_444012936 小时前
mysql如何升级版本至最新_mysql大版本平滑升级策略
jvm·数据库·python
kexnjdcncnxjs6 小时前
mysql如何优化小表的查询索引_mysql全表扫描与索引代价对比
jvm·数据库·python
一只专注api接口开发的技术猿7 小时前
京东商品实时监控选品实战:用 Open Claw API 快速搭建自动化工具
运维·数据库·自动化