当前位置:首页 > 技术分析 > 正文内容

Rust语言从入门到精通系列 - SeaORM框架实战(数据库DML篇)

ruisui883个月前 (01-21)技术分析12

SeaORM是一个Rust语言的ORM框架,提供了简单易用的API,可以帮助我们轻松地操作数据库。SeaORM支持多种数据库,包括MySQL、PostgreSQL、SQLite等等。

在本教程中,我们将以Animal实体为例,介绍SeaORM的基本用法,包括创建表、增删改查等操作。

准备工作

在MySQL中创建一个名为animals的数据库,并在其中创建一个名为animal的表,用于存储动物的信息。表结构如下:

CREATE TABLE `animal` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL,
  `age` int(11) NOT NULL,
  `species` varchar(255) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

定义Entity

在SeaORM中,我们可以通过定义实体来操作数据库。实体通常对应着数据库中的一张表。在本例中,我们需要创建一个Animal实体,对应着animal表。

首先,我们需要在Cargo.toml中添加SeaORM和MySQL驱动程序的依赖:

[dependencies]
sea-orm = "0.11.3"

然后,在src目录下创建一个名为animal.rs的文件,定义Animal实体:

use sea_orm::entity::prelude::*;

#[derive(Clone, Debug, PartialEq, DeriveEntityModel)]
#[sea_orm(table_name = "animal")]
pub struct Animal {
    #[sea_orm(primary_key)]
    pub id: i32,
    pub name: String,
    pub age: i32,
    pub species: String,
}

这里我们使用了derive宏来自动生成Animal实体的代码。其中,#[sea_orm(table_name = "animal")]表示Animal实体对应的表名为animal#[sea_orm(primary_key)]表示id字段为主键。

有了Animal实体之后,我们就可以使用SeaORM提供的API来操作数据库了。下面分别介绍如何进行增删改查操作。

增加记录

要增加一条记录,我们可以使用Animal::insert()方法。例如,要添加一只名为“Tom”的2岁猫,可以这样写:

use sea_orm::{Database, EntityTrait, FromQueryResult};

let database_url = "mysql://root:password@localhost:3306/animals";
let db = Database::connect(database_url).await.unwrap();

let animal = Animal {
    id: 0,
    name: "Tom".to_owned(),
    age: 2,
    species: "cat".to_owned(),
};

let inserted_animal = Animal::insert(&animal).exec(&db).await.unwrap();

这里我们首先连接到了名为animals的MySQL数据库,然后创建了一只名为“Tom”的2岁猫,使用Animal::insert()方法将其插入到数据库中,最后返回插入的记录。

删除记录

要删除一条记录,我们可以使用Animal::delete()方法。例如,要删除id为1的记录,可以这样写:

use sea_orm::{Database, EntityTrait, FromQueryResult};

let database_url = "mysql://root:password@localhost:3306/animals";
let db = Database::connect(database_url).await.unwrap();

let deleted_animal = Animal::delete()
    .filter(animal::Column::Id.eq(1))
    .exec(&db)
    .await
    .unwrap();

这里我们使用Animal::delete()方法删除了id为1的记录,使用filter()方法指定了要删除的记录,最后返回删除的记录。

更新记录

要更新一条记录,我们可以使用Animal::update()方法。例如,要将id为1的记录的年龄改为3岁,可以这样写:

use sea_orm::{Database, EntityTrait, FromQueryResult};

let database_url = "mysql://root:password@localhost:3306/animals";
let db = Database::connect(database_url).await.unwrap();

let updated_animal = Animal::update()
    .set(animal::Column::Age, 3)
    .filter(animal::Column::Id.eq(1))
    .exec(&db)
    .await
    .unwrap();

这里我们使用Animal::update()方法更新了id为1的记录,使用set()方法指定了要更新的字段,最后返回更新后的记录。

查询记录

要查询记录,我们可以使用Animal::find()方法。例如,要查询所有名字为“Tom”的动物,可以这样写:

use sea_orm::{Database, EntityTrait, FromQueryResult};

let database_url = "mysql://root:password@localhost:3306/animals";
let db = Database::connect(database_url).await.unwrap();

let animals = Animal::find()
    .filter(animal::Column::Name.eq("Tom"))
    .all(&db)
    .await
    .unwrap();

这里我们使用Animal::find()方法查询了所有名字为“Tom”的动物,使用filter()方法指定了查询条件,最后返回查询结果。

联表查询

除了基本的增删改查操作之外,SeaORM还支持联表查询。例如,我们可以查询每个物种的平均年龄:

use sea_orm::{Database, EntityTrait, FromQueryResult};

let database_url = "mysql://root:password@localhost:3306/animals";
let db = Database::connect(database_url).await.unwrap();

let avg_age_by_species = Animal::find()
    .group_by(animal::Column::Species)
    .select((animal::Column::Species, Avg(animal::Column::Age)))
    .all(&db)
    .await
    .unwrap();

这里我们使用Animal::find()方法查询了所有动物的信息,使用group_by()方法指定了分组条件,使用select()方法指定了要查询的字段和聚合函数,最后返回查询结果。

总结

本教程介绍了SeaORM的基本用法,包括创建实体、增删改查等操作。SeaORM提供了简单易用的API,可以帮助我们轻松地操作数据库。同时,SeaORM还支持多种数据库,包括MySQL、PostgreSQL、SQLite等等。

在实际开发中,我们可以根据需要选择不同的数据库和ORM框架。SeaORM是一个不错的选择,它提供了很多有用的功能,可以帮助我们更加高效地开发应用程序。

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/431.html

标签: c# orm框架
分享给朋友:

“Rust语言从入门到精通系列 - SeaORM框架实战(数据库DML篇)” 的相关文章

内存问题探微

这篇文章是我在公司 TechDay 上分享的内容的文字实录版,本来不想写这么一篇冗长的文章,因为有不少的同学问是否能写一篇相关的文字版,本来没有的也就有了。说起来这是我第二次在 TechDay 上做的分享,四年前第一届 TechDay 不知天高地厚,上去讲了一个《MySQL 最佳实践》,现在想起来那...

7 招教你轻松搭建以图搜图系统

作者 | 小龙责编 | 胡巍巍当您听到“以图搜图”时,是否首先想到了百度、Google 等搜索引擎的以图搜图功能呢?事实上,您完全可以搭建一个属于自己的以图搜图系统:自己建立图片库;自己选择一张图片到库中进行搜索,并得到与其相似的若干图片。Milvus 作为一款针对海量特征向量的相似性检索引擎,旨在...

10款超牛Vim插件,爱不释手了

我是一个忠实的Vim编辑器用户,从事开发工作多年,我一直都非常喜欢使用Vim。轻量、便捷,而且,熟悉了Vim相关的快捷键之后,效率能够成倍的提升。除了这些之外,Vim像很多知名的IDE、编辑器一样,也支持插件配置,通过这些插件,可以实现更多高级、高效的操作。今天,就来给大家分享10个我特别喜欢的Vi...

我的VIM配置

写一篇关于VIM配置的文章,记录下自己的VIM配置,力求简洁实用。VIM的配置保存在文件~/.vimrc中(Windows下是C:\Users\yourname \_vimrc)。VIM除了自身可配置项外,还可插件扩展。VIM的插件一般用vundle或vim-plug来管理,但我力求简单,不打算装太...

vue v-html动态生成的html怎么加样式/事件

1、动态生成的html,样式不生效//html 布局 <view v-html="html"> {{html}} </view> //动态生成的元素 <view class="btngo" @tap="handleLink...

Gemini应用在Android上广泛推出2.0闪电模式切换器

#头条精品计划# 快速导读谷歌(搜索)应用的测试频道在安卓设备的双子应用中推出了2.0闪电实验功能,现已向稳定用户开放。双子应用通过谷歌应用运行,目前推出的15.50版本中,用户可通过模型选择器体验不同选项,包括1.5专业版、1.5闪电版和2.0闪电实验版。2.0闪电实验模型提供了更快的响应速度和优...