当前位置: 首页 > article >正文

8.Rust+Axum 数据库集成实战:从 ORM 选型到用户管理系统开发

摘要

深入探讨 Rust+Axum 数据库集成,包括 ORM 选型及实践,助力用户管理系统开发。

一、引言

在现代 Web 应用开发中,数据库集成是至关重要的一环。Rust 凭借其高性能、内存安全等特性,与 Axum 这个轻量级且高效的 Web 框架结合,能为开发者打造出优秀的后端服务。而在数据库操作方面,合理选择 ORM(对象关系映射)工具并进行正确配置,对于提升开发效率和代码质量有着显著作用。本文将详细介绍 Rust+Axum 中数据库集成的相关内容,包括 ORM 选型、异步连接池配置、事务管理与连接生命周期,最后通过用户管理系统的 CRUD 开发实践来加深理解。

二、ORM 选型:SQLx 与 SeaORM

2.1 SQLx

SQLx 是一个基于 Rust 的异步 SQL 工具包,它并非传统意义上的 ORM,而是更侧重于类型安全的 SQL 查询。其优势在于能直接执行 SQL 语句,减少了抽象层带来的性能损耗,并且对多种数据库有良好的支持,如 PostgreSQL、MySQL、SQLite 等。例如,在项目中使用 SQLx 可以直接编写 SQL 查询语句,编译器会对其进行类型检查,确保查询的正确性。

2.2 SeaORM

SeaORM 是一个功能齐全的 Rust ORM,它提供了类似于其他编程语言中 ORM 的丰富功能,如实体映射、查询构建器等。SeaORM 具有良好的抽象性,能让开发者以面向对象的方式操作数据库,减少 SQL 语句的编写量,提高开发效率。它同样支持多种数据库,适用于不同规模的项目。

2.3 选型建议

如果项目对性能要求极高,且开发者熟悉 SQL 语句,希望直接操作数据库,那么 SQLx 是一个不错的选择。而如果项目规模较大,需要更高级的抽象和便捷的数据库操作方式,SeaORM 则更合适。

三、异步连接池配置

3.1 SQLx 异步连接池配置

以下是使用 SQLx 配置 PostgreSQL 异步连接池的示例代码:

use sqlx::postgres::{PgPool, PgPoolOptions};#[tokio::main]
async fn main() -> Result<(), sqlx::Error> {let database_url = "postgres://user:password@localhost:5432/mydb";let pool = PgPoolOptions::new().max_connections(5).connect(database_url).await?;// 使用连接池进行数据库操作Ok(())
}

在上述代码中,我们使用 PgPoolOptions 来配置连接池的最大连接数,并通过 connect 方法连接到 PostgreSQL 数据库。

3.2 SeaORM 异步连接池配置

以下是使用 SeaORM 配置 MySQL 异步连接池的示例代码:

use sea_orm::{Database, DatabaseConnection};#[tokio::main]
async fn main() -> Result<(), sea_orm::DbErr> {let database_url = "mysql://user:password@localhost:3306/mydb";let conn: DatabaseConnection = Database::connect(database_url).await?;// 使用连接进行数据库操作Ok(())
}

在这个示例中,我们使用 Database::connect 方法连接到 MySQL 数据库,SeaORM 会自动管理连接池。

四、事务管理与连接生命周期

4.1 事务管理

事务是数据库操作中保证数据一致性的重要机制。在 SQLx 中,可以通过以下方式实现事务管理:

use sqlx::{Transaction, postgres::PgPool};async fn perform_transaction(pool: &PgPool) -> Result<(), sqlx::Error> {let mut tx: Transaction<'_, sqlx::Postgres> = pool.begin().await?;// 执行一系列数据库操作sqlx::query("INSERT INTO users (name, email) VALUES ($1, $2)").bind("John Doe").bind("johndoe@example.com").execute(&mut tx).await?;// 提交事务tx.commit().await?;Ok(())
}

在 SeaORM 中,事务管理类似:

use sea_orm::{TransactionTrait, DatabaseConnection};async fn perform_transaction(conn: &DatabaseConnection) -> Result<(), sea_orm::DbErr> {let tx = conn.begin().await?;// 执行数据库操作// ...tx.commit().await?;Ok(())
}

4.2 连接生命周期

连接池会管理连接的生命周期,确保连接的复用和有效释放。在使用连接池时,开发者无需手动管理连接的打开和关闭,只需从连接池中获取连接进行操作即可。当操作完成后,连接会自动返回连接池,等待下一次使用。

五、实践:用户管理系统 CRUD 开发

5.1 项目初始化

首先,创建一个新的 Rust 项目,并添加 Axum、SQLx 或 SeaORM 等依赖:

[dependencies]
axum = "0.6"
sqlx = { version = "0.6", features = ["postgres", "runtime-tokio-native-tls"] }
tokio = { version = "1", features = ["full"] }

5.2 定义数据模型

以 SQLx 为例,定义用户表的模型:

use sqlx::FromRow;#[derive(Debug, FromRow)]
struct User {id: i32,name: String,email: String,
}

5.3 实现 CRUD 操作

以下是使用 Axum 和 SQLx 实现用户管理系统 CRUD 操作的示例代码:

use axum::{routing::{get, post, put, delete},Router,extract::{Path, State},Json,
};
use sqlx::postgres::PgPool;
use serde::{Deserialize, Serialize};#[derive(Debug, Serialize, Deserialize)]
struct CreateUser {name: String,email: String,
}async fn create_user(State(pool): State<PgPool>,Json(user): Json<CreateUser>,
) -> Result<Json<User>, sqlx::Error> {let new_user = sqlx::query_as!(User,"INSERT INTO users (name, email) VALUES ($1, $2) RETURNING id, name, email",user.name,user.email).fetch_one(&pool).await?;Ok(Json(new_user))
}// 实现其他 CRUD 操作,如获取用户、更新用户、删除用户等#[tokio::main]
async fn main() {let database_url = "postgres://user:password@localhost:5432/mydb";let pool = PgPool::connect(database_url).await.unwrap();let app = Router::new().route("/users", post(create_user));axum::Server::bind(&"127.0.0.1:3000".parse().unwrap()).serve(app.into_make_service()).await.unwrap();
}

六、总结

通过本文的介绍,我们了解了 Rust+Axum 中数据库集成的相关知识,包括 ORM 选型、异步连接池配置、事务管理与连接生命周期,以及用户管理系统的 CRUD 开发实践。合理选择 ORM 工具并正确配置数据库连接池,能为开发高性能、稳定的 Web 应用奠定坚实基础。在实际项目中,开发者可以根据项目需求和自身技术栈来选择合适的方案。

相关文章:

8.Rust+Axum 数据库集成实战:从 ORM 选型到用户管理系统开发

摘要 深入探讨 RustAxum 数据库集成&#xff0c;包括 ORM 选型及实践&#xff0c;助力用户管理系统开发。 一、引言 在现代 Web 应用开发中&#xff0c;数据库集成是至关重要的一环。Rust 凭借其高性能、内存安全等特性&#xff0c;与 Axum 这个轻量级且高效的 Web 框架结合…...

电脑 BIOS 操作指南(Computer BIOS Operation Guide)

电脑 BIOS 操作指南 电脑的BIOS界面&#xff08;应为“BIOS”&#xff09;是一个固件界面&#xff0c;允许用户配置电脑的硬件设置。 进入BIOS后&#xff0c;你可以进行多种设置&#xff0c;具体包括&#xff1a; 1.启动配置 启动顺序&#xff1a;设置从哪个设备启动&#x…...

MySQL快速入门篇---库的操作

目录 一、创建数据库 1.语法 2.示例 二、查看数据库 1.语法 三、字符集编码和校验&#xff08;排序&#xff09;规则 1.查看数据库支持的字符集编码 2.查看数据库支持的排序规则 3.查看系统默认字符集和排序规则 3.1.查看系统默认字符集 3.2.查看系统默认排序规则 ​…...

前端:uniapp中uni.pageScrollTo方法与元素的overflow-y:auto之间的关联

在uniapp中&#xff0c;uni.pageScrollTo方法与元素的overflow-y:auto属性之间存在以下关联和差异&#xff1a; 一、功能定位差异 ‌uni.pageScrollTo‌ 属于‌页面级滚动控制‌&#xff0c;作用于整个页面容器‌34。要求页面内容高度必须超过屏幕高度&#xff0c;且由根元素下…...

【已更新完毕】2025华中杯B题数学建模网络挑战赛思路代码文章教学:校园共享单车的调度与维护问题

完整内容请看文末最后的推广群 构建校园共享单车的调度与维护问题 摘要 共享单车作为一种便捷、环保的短途出行工具&#xff0c;近年来在高校校园内得到了广泛应用。然而&#xff0c;共享单车的运营也面临一些挑战。某高校引入共享单车后&#xff0c;委托学生对运营情况进行调…...

NO.92十六届蓝桥杯备战|图论基础-最小生成树-Prim算法-Kruskal算法|买礼物|繁忙的都市|滑雪(C++)

一个具有n个顶点的连通图&#xff0c;其⽣成树为包含n-1条边和所有顶点的极⼩连通⼦图。对于⽣成树来说&#xff0c;若砍去⼀条边就会使图不连通图&#xff1b;若增加⼀条边就会形成回路。 ⼀个图的⽣成树可能有多个&#xff0c;将所有⽣成树中权值之和最⼩的树称为最⼩⽣成树…...

第十四节:实战场景-何实现全局状态管理?

React.createElement调用示例 Babel插件对JSX的转换逻辑 React 全局状态管理实战与 JSX 转换原理深度解析 一、React 全局状态管理实现方案 1. Context API useReducer 方案&#xff08;轻量级首选&#xff09; // 创建全局 Context 对象 const GlobalContext createConte…...

数据驱动、精准协同:高端装备制造业三位一体生产管控体系构建

开篇引入 鉴于集团全面推行生产运营体建设以及对二级单位生产过程管控力度逐步加强&#xff0c;某高端装备制造企业生产部长王总正在开展新的一年企业生产管控规划工作&#xff0c;为了能够更好地进行体系规划与建设应用&#xff0c;特邀请智能制造专家小智来进行讨论交流。 王…...

航电系统之通信技术篇

航电系统&#xff08;航空电子系统&#xff09;的通信技术是现代航空器的核心技术之一&#xff0c;其核心目标是实现飞行器内部各系统之间以及飞行器与外部设备&#xff08;如地面控制中心、其他飞行器等&#xff09;之间高效、可靠的信息交互。随着航空技术的不断发展&#xf…...

Linux 日常运维命令大全

Linux 作为一种开源操作系统&#xff0c;在服务器运维中扮演着重要角色。掌握常用的 Linux 命令对于运维人员而言至关重要。本文将整理一份 Linux 服务器运维常用命令大全&#xff0c;帮助你在日常工作中提高效率和准确性。 1. 基础命令 基础命令是Linux操作的起点&#xff0…...

HTTP 3.0 协议的特点

HTTP/3 是互联网传输协议的一次重要升级&#xff0c;相较于 HTTP/2&#xff0c;它引入了多项显著改进和新特性。 基于 QUIC 协议&#xff1a; HTTP/3 采用了 QUIC&#xff08;Quick UDP Internet Connections&#xff09;作为底层传输协议&#xff0c;QUIC 基于 UDP&#xff0…...

[工具]Java xml 转 Json

[工具]Java xml 转 Json 依赖 <!-- https://mvnrepository.com/artifact/cn.hutool/hutool-all --> <dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.37</version> </dependen…...

「仓颉编程语言」Demo

仓颉编程语言」Demo python 1)# 仓颉语言写字楼管理系统示例&#xff08;虚构语法&#xff09;# 语法规则&#xff1a;中文关键词 类Python逻辑定义 写字楼管理系统属性:租户库 列表.新建()报修队列 列表.新建()费用单价 5 # 元/平方米方法 添加租户(名称, 楼层, 面积):…...

发现“横”字手写有难度,对比两个“横”字

我发现手写体“横”字“好看”程度&#xff0c;难以比得上印刷体&#xff1a; 两个从方正简体启体来的“横”字&#xff1a; 哪个更好看&#xff1f;我是倾向于左边一点。 <div style"transform: rotate(180deg); display: inline-block;"> 左边是我从方正简…...

深度学习3.1 线性回归

3.1.1 线性回归的基本概念 损失函数 梯度下降 3.1.2 向量化加速 %matplotlib inline import math import time import numpy as np import torch from d2l import torch as d2ln 1000000 #本机为了差距明显&#xff0c;选择数据较大&#xff0c;运行时间较长&#xff0c;可选…...

番外篇 | SEAM-YOLO:引入SEAM系列注意力机制,提升遮挡小目标的检测性能

前言:Hello大家好,我是小哥谈。SEAM(Squeeze-and-Excitation Attention Module)系列注意力机制是一种高效的特征增强方法,特别适合处理遮挡和小目标检测问题。该机制通过建模通道间关系来自适应地重新校准通道特征响应。在遮挡小目标检测中的应用优势包括:1)通道注意力增强…...

SpringBoot ApplicationEvent:事件发布与监听机制

文章目录 引言一、事件机制的基本概念二、创建自定义事件2.1 定义事件类2.2 发布事件2.3 简化的事件发布 三、创建事件监听器3.1 使用EventListener注解3.2 实现ApplicationListener接口3.3 监听非ApplicationEvent类型的事件 四、事件监听的高级特性4.1 条件事件监听4.2 异步事…...

[250415] OpenAI 推出 GPT-4.1 系列,支持 1M token

目录 OpenAI 推出 GPT-4.1 系列 OpenAI 推出 GPT-4.1 系列 OpenAI 宣布&#xff0c;新一代 GPT-4.1 模型系列正式发布&#xff0c;包括 GPT-4.1, GPT-4.1 mini 和 GPT-4.1 nano 三款模型&#xff0c;该系列模型在各项性能指标上全面超越 GPT-4o 和 GPT-4o mini&#xff0c;尤其…...

广东2024信息安全管理与评估一阶段答案截图

2023-2024 学年广东省职业院校技能大赛 高等职业教育组 信息安全管理与评估 赛题一 模块一 网络平台搭建与设备安全防护 一、 比赛时间 本阶段比赛时间为 180 分钟。 二、 赛项信息 竞赛阶段 任务阶段 竞赛任务 竞赛时间 分值 第一…...

C++_设计模式\_观察者模式(Observer Pattern)

&#x1f44b; Hi, I’m liubo&#x1f440; I’m interested in harmony&#x1f331; I’m currently learning harmony&#x1f49e;️ I’m looking to collaborate on …&#x1f4eb; How to reach me …&#x1f4c7; sssssdsdsdsdsdsdasd&#x1f383; dsdsdsdsdsddfsg…...

安卓手机如何改ip地址教程

对于安卓手机用户而言&#xff0c;ip修改用在电商、跨境电商、游戏搬砖、社交软件这些需要开多个账号的项目。因为多个设备或账号又不能在同一ip网络下&#xff0c;所以修改手机的IP地址防检测成为一个必要的操作。以下是在安卓手机上更改IP地址的多种方法及详细步骤&#xff0…...

​​从Shell到域控:内网渗透中定位域控制器的8种核心方法​

在内网渗透中&#xff0c;定位域控制器&#xff08;Domain Controller, DC&#xff09;是攻防对抗的关键环节。本文结合实战经验与工具技术&#xff0c;总结出​​8种从Shell快速发现域控主机的方法​​&#xff0c;涵盖命令探测、网络扫描、日志分析等维度&#xff0c;助你系统…...

PHP腾讯云人脸核身获取Access Token

参考腾讯云官方文档&#xff1a; 人脸核身 获取 Access Token_腾讯云 public function getAccessToken(){$data [appId > , //WBappid,https://cloud.tencent.com/document/product/1007/49634secret > ,grant_type > client_credential, //授权类型version > 1…...

Kotlin 集合过滤全指南:all、any、filter 及高级用法

在 Kotlin 中&#xff0c;集合过滤是数据处理的核心操作之一。无论是简单的条件筛选&#xff0c;还是复杂的多条件组合&#xff0c;Kotlin 都提供了丰富的 API。本文将详细介绍 filter、all、any、none 等操作符的用法&#xff0c;并展示如何在实际开发中灵活运用它们。 1. 基础…...

解决6栈6层码头集装箱堆栈翻箱最优解问题

‘’’ con 1 origin_stack = [ [4, 4, 1, 0, 0, 0], # 第一栈 [4, 3, 2, 1, 0, 0], # 第二栈 [4, 2, 2, 1, 0, 0], # 第三栈 [3, 3, 3, 1, 0, 0], # 第四栈 [3, 4, 2, 1, 0, 0], # 第五栈 [4, 2, 3, 2, 0, 0] # 第六栈 ] con 2 origin_stack = [ [4, 4, 3, 0, 0, 0], # 第一栈…...

flutter app实现分辨率自适应的图片资源加载

在 Flutter 中&#xff0c;为了实现分辨率自适应的图片资源加载&#xff0c;确实需要遵循特定的目录结构和命名规则。这种机制允许 AssetImage 根据设备的 设备像素比&#xff08;Device Pixel Ratio, DPR&#xff09; 自动选择最合适的图片资源。以下是详细的说明和实现步骤&a…...

软件测试之测试数据生成(Excel版)

这是Excel生成测试数据的函数使用 1.时间 1.1.时间 例生成2022-05-01之前一年内任意时间点: =TEXT("2022-05-01"-RAND()-RANDBETWEEN(1,365),"yyyy-mm-dd hh:mm:ss")1.2.年月日 yyyy-mm-dd 以当前时间生成10年的日期 =TEXT(NOW()-RAND()-RANDBETWE…...

(51单片机)LCD显示数据存储(DS1302时钟模块教学)(LCD1602教程)(独立按键教程)(延时函数教程)(I2C总线认识)(AT24C02认识)

目录 演示视频&#xff1a; 源代码 main.c LCD1602.c LCD1602.h AT24C02.c AT24C02.h Key.c Key.h I2C.c I2C.h Delay.c Delay.h 代码解析与教程&#xff1a; Dealy模块 LCD1602模块 Key模块 I2C总线模块 AT24C02模块 /E2PROM模块 main模块 演示视频&#xff1a; &…...

STL简介 + string【上】

一 . STL简介 1.1 什么是STL STL&#xff08;standard template libaray - 标准模板库) : 是C标准库的重要组成部分 &#xff0c; 不仅是一个可复用的组件库 &#xff0c; 而且是一个包罗 数据结构 与 算法 的软件框架 。 注意 &#xff1a; 是标准库的一部分 &#xff…...

【Bluedroid】A2DP Sink播放流程源码分析(二)

接上一篇继续分析:【Bluedroid】A2DP Sink播放流程源码分析(一)_安卓a2dp sink播放流程-CSDN博客 AVDTP接收端(Sink)流事件处理 bta_av_sink_data_cback 是 Bluedroid 中 A2DP Sink 角色的 AVDTP 数据回调函数,负责处理接收端的音频数据事件,将底层接收到的音频数据传递…...