FastAPI - Tortoise ORM 数据库基础操作

文章目录

      • 1. 安装 Tortoise ORM
      • 2. 定义模型
      • 3. 初始化数据库连接
      • 4. 数据库操作
        • 4.1 创建数据
        • 4.2 查询数据
        • 4.3 更新数据
        • 4.4 删除数据
      • 5. 使用 Pydantic 模型
      • 6. 关闭数据库连接
      • 7. fields类相关操作
        • 1. `fields.IntField`
        • 2. `fields.BigIntField`
        • 3. `fields.SmallIntField`
        • 4. `fields.CharField`
        • 5. `fields.TextField`
        • 6. `fields.BooleanField`
        • 7. `fields.FloatField`
        • 8. `fields.DecimalField`
        • 9. `fields.DatetimeField`
        • 10. `fields.DateField`
        • 11. `fields.TimeField`
        • 12. `fields.JSONField`
        • 13. `fields.BinaryField`
        • 14. `fields.ForeignKeyField`
        • 15. `fields.ManyToManyField`
        • 16. `fields.OneToOneField`
        • 其他字段
      • 8. ORM(对象关系映射)数据迁移
        • 1. 初始化迁移环境
        • 2. 创建迁移文件
        • 3. 应用迁移
        • 4. 查看迁移状态
        • 5. 回滚迁移
        • 6. 生成模型
        • 7. 清除迁移历史


Tortoise ORM 是一个异步的 ORM 框架,使用 Python 的类和对象来操作数据库,不需要编写 SQL 语句。


1. 安装 Tortoise ORM

首先,确保已经安装 Tortoise ORM。如果还没有安装,可以使用 pip 来安装:

pip install tortoise-orm

2. 定义模型

使用 Tortoise ORM, 需要定义模型类来表示数据库中的表。模型类继承自 tortoise.models.Model

from tortoise import fields, models
from tortoise.contrib.pydantic import pydantic_model_creator

class Tournament(models.Model):
    id = fields.IntField(pk=True)
    name = fields.CharField(max_length=255)
    created_at = fields.DatetimeField(auto_now_add=True)

    class Meta:
        table = 'tournaments'  # 自定义表名

# 创建 Pydantic 模型
Tournament_Pydantic = pydantic_model_creator(Tournament, name="Tournament")

3. 初始化数据库连接

在使用 Tortoise ORM 之前,需要初始化数据库连接。

from tortoise import Tortoise, run_async

async def init_db():
    # 这里使用 SQLite 数据库作为示例
    await Tortoise.init(
        db_url='sqlite://db.sqlite3',
        modules={'models': ['your_app']}  # 你的模型所在的模块
    )
    # 生成数据库表结构
    await Tortoise.generate_schemas()

# 运行初始化函数
run_async(init_db())

4. 数据库操作

定义好模型和数据库连接后,可以进行各种数据库操作。

4.1 创建数据
async def create_tournament():
    tournament = await Tournament.create(name='New Tournament')
    print(f'Created tournament with id: {tournament.id}')

run_async(create_tournament())
4.2 查询数据
async def get_tournaments():
    tournaments = await Tournament.all()
    for tournament in tournaments:
        print(f'Tournament: {tournament.name}')

run_async(get_tournaments())
4.3 更新数据
async def update_tournament(tournament_id: int, new_name: str):
    await Tournament.filter(id=tournament_id).update(name=new_name)
    print(f'Updated tournament with id: {tournament_id}')

run_async(update_tournament(1, 'Updated Tournament'))
4.4 删除数据
async def delete_tournament(tournament_id: int):
    await Tournament.filter(id=tournament_id).delete()
    print(f'Deleted tournament with id: {tournament_id}')

run_async(delete_tournament(1))

5. 使用 Pydantic 模型

Tortoise ORM 提供了 pydantic_model_creator 函数,可以自动生成 Pydantic 模型。

# 创建 Pydantic 模型
Tournament_Pydantic = pydantic_model_creator(Tournament, name="Tournament")

# 使用 Pydantic 模型
tournament_data = Tournament_Pydantic.from_orm(tournament)
print(tournament_data.json())

6. 关闭数据库连接

在应用结束时,确保关闭数据库连接。

from tortoise import Tortoise

# 关闭数据库连接
@app.on_event("shutdown")
async def close_orm():
    await Tortoise.close_connections()

7. fields类相关操作

在 Tortoise ORM 中,fields 是模型中用于定义数据库表字段的类。这些字段类定义了数据库表中每个字段的类型、约束和其他属性。以下是 Tortoise ORM 中一些常用的 fields 类:

1. fields.IntField

用于定义整数字段。

from tortoise import fields

class MyModel(Model):
    id = fields.IntField(pk=True)
2. fields.BigIntField

用于定义大整数字段。

from tortoise import fields

class MyModel(Model):
    id = fields.BigIntField(pk=True)
3. fields.SmallIntField

用于定义小整数字段。

from tortoise import fields

class MyModel(Model):
    id = fields.SmallIntField(pk=True)
4. fields.CharField

用于定义字符字段,通常用于存储短文本。

from tortoise import fields

class MyModel(Model):
    name = fields.CharField(max_length=255)
5. fields.TextField

用于定义文本字段,通常用于存储长文本。

from tortoise import fields

class MyModel(Model):
    description = fields.TextField()
6. fields.BooleanField

用于定义布尔字段。

from tortoise import fields

class MyModel(Model):
    is_active = fields.BooleanField()
7. fields.FloatField

用于定义浮点数字段。

from tortoise import fields

class MyModel(Model):
    price = fields.FloatField()
8. fields.DecimalField

用于定义精确小数字段。

from tortoise import fields

class MyModel(Model):
    balance = fields.DecimalField(max_digits=10, decimal_places=2)
9. fields.DatetimeField

用于定义日期时间字段。

from tortoise import fields

class MyModel(Model):
    created_at = fields.DatetimeField(auto_now_add=True)
10. fields.DateField

用于定义日期字段。

from tortoise import fields

class MyModel(Model):
    birth_date = fields.DateField()
11. fields.TimeField

用于定义时间字段。

from tortoise import fields

class MyModel(Model):
    start_time = fields.TimeField()
12. fields.JSONField

用于定义 JSON 字段,可以存储复杂的数据结构。

from tortoise import fields

class MyModel(Model):
    data = fields.JSONField()
13. fields.BinaryField

用于定义二进制字段,可以存储二进制数据。

from tortoise import fields

class MyModel(Model):
    image = fields.BinaryField()
14. fields.ForeignKeyField

用于定义外键字段,用于建立模型之间的关系。

from tortoise import fields

class MyModel(Model):
    user = fields.ForeignKeyField('models.User')
15. fields.ManyToManyField

用于定义多对多字段,用于建立模型之间的多对多关系。

from tortoise import fields

class MyModel(Model):
    tags = fields.ManyToManyField('models.Tag')
16. fields.OneToOneField

用于定义一对一字段,用于建立模型之间的关系。

from tortoise import fields

class MyModel(Model):
    profile = fields.OneToOneField('models.Profile')
其他字段

Tortoise ORM 还提供了其他一些字段,如 fields.UUIDFieldfields.IPAddressFieldfields.EmailField 等,用于处理特定类型的数据。

在定义模型字段时,可以设置各种属性,如 nulldefaultpkuniqueindex 等,以控制字段的行为和约束。


8. ORM(对象关系映射)数据迁移

ORM(对象关系映射)数据迁移是管理数据库模式更改的过程。在使用 ORM 时,通常会使用 ORM 提供的迁移工具来处理数据库模式的变更,而不是直接编写 SQL 语句。以下是一些常见的 ORM 迁移命令:

1. 初始化迁移环境

在开始使用迁移之前,需要初始化迁移环境, 涉及到设置数据库连接和配置迁移目录。

# 使用 Tortoise ORM 的迁移工具
tortoise-orm init-db
2. 创建迁移文件

一旦迁移环境设置好,可以创建迁移文件来描述你的数据库模式更改。

# 创建一个新的迁移文件
tortoise-orm makemigrations

这将生成一个新的迁移文件,其中包含了对数据库模式的更改。

3. 应用迁移

创建迁移文件后,可以应用这些迁移来更新数据库模式。

# 应用所有未应用的迁移
tortoise-orm migrate
4. 查看迁移状态

如果查看当前的迁移状态,可以使用以下命令:

# 查看当前的迁移状态
tortoise-orm showmigrations
5. 回滚迁移

如果需要回滚迁移,可以使用命令:

# 回滚最近的一次迁移
tortoise-orm migrate --revision=-1
6. 生成模型

如果需要根据数据库生成模型,可以使用命令:

# 生成模型
tortoise-orm inspectdb
7. 清除迁移历史

如果清除迁移历史,可以使用命令:

# 清除迁移历史
tortoise-orm reset

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/597479.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Vue 插槽

Vue插槽是一种特殊的语法,用于在组件中定义可复用的模板部分。它允许开发者在组件的标记中声明一个或多个插槽,然后在使用该组件时,可以根据自己的需求将内容插入到这些插槽中。 Vue插槽分为默认插槽和具名插槽两种。 默认插槽 语法 组件…

中国科技大航海时代,“掘金”一带一路

文|白 鸽 编|王一粟 “这不就是90年代的内地吗?” 在深度考察完沙特市场后,华盛集团联合创始人兼CEO张霆对镜相工作室感慨道。 在张霆看来,沙特落后的基建(意味着大量创新空间)、刚刚开放…

18.Blender 渲染工程、打光方法及HDR贴图导入

HDR环境 如何导入Blender的HDR环境图 找到材质球信息 在右上角,点击箭头,展开详细部分 点击材质球,会出现下面一列材质球,将鼠标拖到第二个材质球,会显示信息 courtyard.exr 右上角打开已渲染模式 左边这里选择世界…

01、JMS规范介绍

01、JMS规范介绍 在我们正式学习Kafka之前,先来了解下JMS,因为这可以在一定程度上帮助你更加深入的理解和学习Kafka。 1、 JMS简介 JMS,全称Java Mesage Service,即Java消息服务应用程序接口,是一个Java平台中关于面…

HIVE统计WordCount

HIVE WORDCOUNT 目录 HIVE WORDCOUNT 一、WORDCOUNT 1.我们先创建一个新的数据库 2.创建表并插入数据 3.统计WORDCOUNT 4.UNION ALL 用法 5.WITH AS 用法 1.WORDCOUNT 1)我们先创建一个新的数据库 create database learn3;use learn3; 2)创建表…

产品推荐 | 基于 Virtex UltraScale+ XCVU3P的FACE-VPXSSD-3PA 存储板

01 产品概述 FACE(FPGA Algorithm aCceleration Engine)FPGA算法加速开发引擎是基于FPGA可编程器件构建的一系列算法加速开发引擎平台。FACE-VPXSSD-3PA存储平台是FACE系列中的一员。该平台板载2组2GB 64bit DDR4、2路QSFP28光接口、4个NVME SSD M.2接口…

yum常用命令与lrzsz的在线安装

yum命令 yum( Yellow dog Updater, Modified)是一个在 Fedora 和 RedHat 以及 SUSE 中的 Shell 前端软件包管理器。 基于 RPM 包管理,能够从指定的服务器自动下载 RPM 包并且安装,可以自动处理依赖性关系,并且一次安装…

设备驱动中device_create函数与sys/devices目录

当调用device_create时parent参数为空时,新添加的设备位于sys/devices//sys/devices/virtual目录 以下面代码的为例 my_newcharled.myclass class_create(THIS_MODULE,dtled); my_newcharled.mydevice device_create(my_newcharled.myclass,NULL,my_newcharled.ne…

04-19 周五 GitHub actions-runner 程序解释

04-19 周五 GitHub actions-runner 程序解释 时间版本修改人描述2024年4月19日17:26:17V0.1宋全恒新建文档 简介 本文主要描述了actions-runner-linux-x64-2.315.0.tar.gz这个github actions CI所需要的客户端安装包的重要文件和内容信息。有关GitHub actions 的配置&#xff…

天图通逊|塘厦总仓服务全面升级

尊敬的客户: 您好!为了提供更优质、更高效的物流服务品质,我司针对国内塘厦仓库进行全面优化升级。升级内容如下: 1.分拣设备升级:在原有的自动分拣设备进行升级,由1.0速升级为1.5高速版;将分拣口的数量从…

<网络安全>《77 概念讲解<第十课 物联网常用协议-(近距离通信)感应层协议>》

协议简称全称名称内容说明RFIDRadio Frequency Identification射频识别阅读器与标签之间进行非接触式的数据通信,达到识别目标的目的。RFID的应用非常广泛,典型应用有动物晶片、汽车晶片防盗器、门禁管制、停车场管制、生产线自动化、物料管理。完整的RF…

基于数字证书的移动终端金融安全身份认证规范

基于数字证书的移动终端金融安全身份认证规范 1 范围 本文件规定了基于数字证书的移动终端金融安全身份认证的服务描述、移动终端生命周期管理、服 务生命周期管理、密钥管理、安全及功能、风险控制和运营管理的要求。 本文件适用于银行业金融机构、非银行支付机构&#xff0c…

1.4 初探JdbcTemplate操作

实战目的 掌握Spring框架中JdbcTemplate的使用,实现对数据库的基本操作。理解数据库连接池的工作原理及其在实际开发中的重要性。通过实际操作,加深对Spring框架中ORM(对象关系映射)的理解。 关键技术点 JdbcTemplate操作&…

triton之语法学习

一 基本语法 1 torch中tensor的声明 x = torch.tensor([[1,2, 1, 1, 1, 1, 1, 1],[2,2,2,2,2,2,2,2]],device=cuda) 声明的时候有的时候需要指出数据的类型,不然在kernel中数据类型无法匹配 x = torch.tensor([1,2,1,1,1,1,1,1],dtype = torch.int32,device=cuda) 2 idx id…

小程序激励广告视频多次回调问题

1.问题 2. 激励视频使用及解决方案 官方文档 let videoAd null; // 在页面中定义激励视频广告 Page({/*** 页面的初始数据*/data: {},/*** 生命周期函数--监听页面加载*/onLoad(options) {let that this;// 创建激励视频广告实例if (wx.createRewardedVideoAd) {videoAd w…

计算机网络4——网络层8 软件定义网络 SDN

文章目录 一、介绍1、简介2、原理3、案例1)普通2)负载均衡的例子3)防火墙的例子 二、控制层面1、特征2、层次 一、介绍 1、简介 SDN的概念最初由斯坦福大学N.McKeown于2009年首先提出。当时还只是在学术界进行探讨的一种新的网络体系结构。…

如何全面规避医疗数据安全风险?“一中心三大管控域”打开新思路!

作为医院的核心基础设施,数据库已然演变成了一种具有“资产”属性的重要元素。而随着不断变化的医疗业务场景和日趋严格的合规性要求,如何让安全全方位贯穿医疗数据的生命周期,是一项系统性的建设工作,难点诸多。 基于多年的数据…

商标不做检索分析,直接申请通过率很低!

今天有个网友拿到驳回通知书找到普推知产老杨,让分析驳回通过率如何,他主要两个文字商标和两个图形商标,文字商标都是两个字的,两个字的商标名称基本都有相同或高近,引用了好几个高度近似,直接做驳回复审通…

设备自动化技术商务咨询

​南京纳恩自动化科技有限公司,成立于 2010年。高新技术企业、软件企业,致力于为客户提供最佳的继电保护、电力监控、智慧用电、工业自动化系统以及基于大数据、云系统的产品解决方案和服务。 自动化行业深耕多年,成就丰富的电力自动化行业经…

Ansible 自动化运维工具 - 了解和模块应用

目录 一. Ansible 的相关知识 1.1 Ansible 工具的简介 1.2 Ansible的四大组件 1.3 运维自动化工具 1.4 Ansible 和其它自动化运维工具对比 1.5 Ansible 的优缺点 二. Ansible 环境安装部署 2.1 管理端安装 ansible 2.2 配置主机清单 三. ansible 命令行模块 3.1 comm…
最新文章