域名 AXUM.RS 将于2025年10月到期。我们无意再对其进行续费,我们希望你能够接续这个域名,让更多 AXUM 开发者继续受益。
  • 方案1️⃣AXUM.RS 域名 = 3000
  • 方案2️⃣方案1️⃣ + 本站所有专题原始 Markdown 文档 = 5000
  • 方案3️⃣方案2️⃣ + 本站原始数据库 = 5500
如果你有意接续这份 AXUM 情怀,请与我们取得联系。
说明:
  1. 如果有人购买 AXUM.RS 域名(方案1️⃣),或者该域名到期,本站将启用新的免费域名继续提供服务。
  2. 如果有人购买了 AXUM.RS 域名,且同时购买了内容和/或数据库(方案2️⃣/方案3️⃣),本站将关闭。届时我们或许会以另一种方式与你再相遇。

SeaORM简介

本专题将带你体验 SeaORM 和 axum 开发。

SeaORM 是一个关系型 ORM,用于帮助你像使用动态语言那样,在 Rust 中构建 Web 服务。

SeaORM 特点

  • 异步:基于 SQLx,SeaORM 天生就支持异步。

  • 动态:基于 SeaQuery,SeaORM 让你无需 与 ORM 作斗争,而轻松构建复杂的查询。

  • 可测试:使用模拟连接来编写单元测试,以便测试你的逻辑。

  • 面向服务:快速构建在 API 中加入、过滤、排序和分页数据的服务。

动态:基于 SeaQuery,SeaORM 让你无需 与 ORM 作斗争,而轻松构建复杂的查询。

面向服务:快速构建在 API 中加入、过滤、排序和分页数据的服务。

SeaORM 术语

Model实例只能用于只读操作;如果需要进行写操作,需要使用 ActiveModel 的实例。

SeaORM与数据的映射

示例说明

本专题通过一个简化的文章系统对 SeaORM 和 axum 开发进行讲解。

数据库和运行时

本专题使用 PostgreSQL 数据库,以及 tokio 异步运行时。

分类(category)

字段说明
id主键。自增
name分类名称

文章(article)

字段说明
id主键。自增
category_id外键。文章所属的分类ID
title文章标题
contet文章内容

创建项目

使用 cargo 创建好项目之后,加入以下依赖:

axum="0.5"
tokio={ version="1", features=["full"] }
sea-orm={ version="0.8", features=["runtime-tokio-native-tls", "sqlx-postgres", "debug-print"] }

示例代码

本专题代码位于AxumCourse/axum-with-seaorm仓库

要查看完整内容,请先登录