更改sqlite为mysql

from tortoise import Tortoise
import asyncio
async def init():
user = 'root'
password = '123456'
db_name = 'test'
await Tortoise.init(
#指定mysql信息
db_url=f'mysql://{user}:{password}@127.0.0.1:3306/{db_name}',
#指定models
modules={'models': ['sanic_bp.models']}
)
#按照模型生成表
# await Tortoise.generate_schemas()
asyncio.run(init())

在sanic中使用:

from sanic import Sanic
from tortoise import Tortoise app = Sanic(__name__) @app.listener('after_server_start')
async def notify_server_started(app, loop):
print('sanic sanic服务启动后建立mysql连接')
#实例化mysql连接
await Tortoise.init(
db_url='mysql://root:123456@127.0.0.1:3306/test?maxsize=50&minsize=3',
modules={'models': ['sanic_bp.models']}
)

基础使用


from tortoise.contrib.sanic import register_tortoise register_tortoise(
app, db_url="sqlite://:memory:", modules={"models": ["models"]}, generate_schemas=True
)

sanic 和 fastapi中使用

tortoise-orm 连接多个库

async def run():
await Tortoise.init(
{
#这里面指定两个不同的数据库,虽然它填写的都是一样的
"connections": {
"first": {
"engine": "tortoise.backends.sqlite",
"credentials": {"file_path": "example.sqlite3"},
},
"second": {
"engine": "tortoise.backends.sqlite",
"credentials": {"file_path": "example1.sqlite3"},
},
},
#可以指定多个不同的models, 嗯,它指定的也是一样的
"apps": {
"tournaments": {"models": ["__main__"], "default_connection": "first"},
"events": {"models": ["__main__"], "default_connection": "second"},
},
}
)
#await Tortoise.generate_schemas()
#选取数据库
client = Tortoise.get_connection("first")
#选取 models
second_client = Tortoise.get_connection("second")
#然后这下面就可以进行orm操作了

增删改查

from typing import List
from fastapi import APIRouter, HTTPException
from tortoise.contrib.fastapi import HTTPNotFoundError from schemas.MaintainedData import MaintainedData_Pydantic, MaintainedDataIn_Pydantic
from models.MaintainedData import MaintainedData
from schemas.basic import Response404, Response200 data = APIRouter(tags=['数据模块']) @data.get("/", summary="数据列表", response_model=List[MaintainedData_Pydantic])
async def data_list(order:str,limit: int = 10, page: int = 1):
# limit 是显示的条数 ,page是页数 skip = (page - 1) * limit
# select * from movie limit offset,limit
# select * from movie limit 0,10
return await MaintainedData_Pydantic.from_queryset(MaintainedData.all().offset(skip).limit(limit)) @data.post("/data", summary="新增数据", )
async def add_data(md_data: MaintainedData_Pydantic):
movie_obj = await MaintainedData.create(**md_data.dict(exclude_unset=True))
# movie_obj = await Movie.create(name="",year="",xx="")
return await MaintainedData_Pydantic.from_tortoise_orm(movie_obj) @data.put("/data/{data_id}", summary="编辑数据", responses={404: {"model": HTTPNotFoundError}})
async def update_data(site_id: str, md_data: MaintainedDataIn_Pydantic):
updated_count = await MaintainedData.filter(site_id=site_id).update(**md_data.dict(exclude_unset=True))
print(updated_count)
if not updated_count:
return Response404(msg=f"data {site_id} not found")
return Response200(data=await MaintainedData_Pydantic.from_queryset_single(MaintainedData.get(site_id=site_id))) @data.get("/data/{data_id}", summary="查找数据", response_model=MaintainedData_Pydantic,
responses={404: {"model": HTTPNotFoundError}})
async def get_user(site_id: str):
return await MaintainedData_Pydantic.from_queryset_single(MaintainedData.get(site_id=site_id)) @data.delete("/data/{data_id}", summary="删除数据", responses={404: {"model": HTTPNotFoundError}})
async def del_movie(site_id: str):
deleted_count = await MaintainedData.filter(site_id=site_id).delete()
if not deleted_count:
raise HTTPException(status_code=404, detail=f"data {site_id} not found")
return HTTPException(status_code=200, detail=f"Deleted Movie {site_id}")

models.py

from datetime import datetime
from typing import Optional, Iterable from tortoise import fields, models, BaseDBAsyncClient class MaintainedData(models.Model):
"""
The User model
"""
id = fields.SmallIntField(pk=True, index=True, description="ID", )
site_id = fields.CharField(max_length=20, unique=True, description="网站ID")
site_name = fields.CharField(max_length=128, null=False, description="网站名称")
site_type = fields.CharField(max_length=16, null=False, description="网站类型")
description = fields.CharField(max_length=255, default="",description="网站备注", )
site_path_name = fields.CharField(max_length=128, null=True, description="目录名称")
site_path_url = fields.CharField(max_length=128, null=True, description="目录链接")
status = fields.CharField(max_length=128, null=True, description="脚本状态")
run_computer = fields.CharField(max_length=255, null=True, description="运行电脑")
run_directory = fields.CharField(max_length=255, null=True, description="运行目录")
crawling_time :Optional[datetime]= fields.DatetimeField(auto_add=True, description="运行时间")
err_message = fields.CharField(max_length=255, null=True, description="错误信息")

order by

db_Secc = MaintainedData.all().order_by("crawling_time")

Eum 枚举

class order_byEnum(str, Enum):
pear = ""
banana = '-' @data.get("/", summary="数据列表", response_model=List[MaintainedData_Pydantic])
async def data_list(
order_by: order_byEnum = "",
limit: int = 10,
page: int = 1):
# limit 是显示的条数 ,page是页数
skip = (page - 1) * limit
return await MaintainedData_Pydantic.from_queryset(MaintainedData.all().offset(
skip).limit(
limit).order_by(
f"{order_by}crawling_time"))

FastAPI + tortoise-orm基础使用的更多相关文章

  1. ORM基础知识

    ORM基础知识 一.什么ORM? ORM是Object Relactional Mapping的缩写,即对象关系映射,是将关系型数据库中的数据库结构映射成对象,就可以通过面向对象思想编程. 二.常用的 ...

  2. 深入理解Magento – 第四章 – 模型和ORM基础

    深入理解Magento 作者:Alan Storm 翻译:Hailong Zhang 第四章 – 模型和ORM基础 对于任何一个MVC架构,模型(Model)层的实现都是占据了很大一部分.对于Mage ...

  3. day 67 django 之ORM 基础安装

    一 ORM的基础部分 1 ORM的概念 对象关系映射(Object Relational Mapping(映射),简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 2   ...

  4. Magento模型和ORM基础

    对于任何一个MVC架构,模型(Model)层的实现都是占据了很大一部分.对于Magento来说,模型占据了一个更加重要的位置,因为它常常包含了一部分商业逻辑代码(可以说它对,也可以说它错).这些代码在 ...

  5. Django之ORM基础

    ORM简介 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...

  6. ORM基础之ORM介绍和基础操作

    一.ORM介绍 1.ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过 ...

  7. ORM基础之字段及其参数介绍

    一.外键ForeignKey 1.字段参数 1.to 设置要关联的表 2.to_field 设置要关联的表的字段(一般不设置,默认使用主键id关联) 3.related_name 反向操作时,使用的字 ...

  8. Django models ORM基础操作--白话聊Django系列

    上次我们讲完了views视图,那我们这次来看一下Django强大的ORM,可以这么说,你不懂Django的ORM,你就不懂Django,那废话不多说 ORM又称关系对象映射,在ORM里,一张表就是一个 ...

  9. Python orm基础

    ORM 对象映射关系程序. 通过orm将编程语言的对象模型和数据库的关系模型建立映射关系,这样我们在使用编程语言对数据库进行操作的时候可以直接使用编程语言的对象模型进行操作就可以了,而不用直接使用sq ...

  10. .NET进阶——ORM基础认识

    ORM对象关系映射,对象即实体,关系即关系数据库表.ORM即实现从实体对象关系数据库数据的映射. 本质上就是将数据从一种形式转换到还有一种形式.它详细又有哪些表现呢.咱们一步步学习,一步步分析. OR ...

随机推荐

  1. [CSharpTips]C#读取SQLite数据库中文乱码

    C#读取SQLite数据库中文乱码 C#在读取C++写入数据的Sqlite数据库中的Text内容时,会出现乱码,因为C++默认编码格式为GB2312,而Sqlite编码格式为UTF-8,存入时不统一就 ...

  2. 人人都能看懂的卡西欧fx991cnx玩机指南,手把手教你如何利用计算器的漏洞爆机

    专业术语说明 你是VerB还是VerC 别人问你这个问题的时候不要慌,帮你看你的计算器是Ver几: 同时按住shift.7.开机键 9 5次shift 第一行后半句即是 紧接着可以顺便看看计算器的序列 ...

  3. AI 音辨世界:艺术小白的我,靠这个AI模型,速识音乐流派选择音乐 ⛵

    作者:韩信子@ShowMeAI 数据分析实战系列:https://www.showmeai.tech/tutorials/40 机器学习实战系列:https://www.showmeai.tech/t ...

  4. 牛客练习赛99—C

    数的和与积 https://ac.nowcoder.com/acm/contest/34330/C 思路: 2和4是不可以的,除了3意外其他的都可以用三项解决,其中一项为1,剩余两项分别设为x,y.  ...

  5. KingbaseES R6 集群通过备库clone在线添加新节点

    案例说明: KingbaseES R6集群可以通过图形化方式在线添加新节点,但是在添加新节点clone环节时,是从主库copy数据到新的节点,这样在生产环境,如果数据量大,将会对主库的网络I/O造成压 ...

  6. Java中“指针”的解释以及对“引用”的理解

    Java中"指针"的解释以及对"引用"的理解 初学Java面对对象编程,对于一些概念还真的有点难以理解,主要是因为不由自主的联系到以前学过的C语言知识,时不时的 ...

  7. Elasticsearch高级检索之使用单个字母数字进行分词N-gram tokenizer(不区分大小写)【实战篇】

    一.前言 小编最近在做到一个检索相关的需求,要求按照一个字段的每个字母或者数字进行检索,如果是不设置分词规则的话,英文是按照单词来进行分词的. 小编以7.6.0版本做的功能哈,大家可以根据自己的版本去 ...

  8. 四元数Quaternion的基本运算

    技术背景 在前面一篇文章中我们介绍了欧拉角死锁问题的一些产生背景,还有基于四元数的求解方案.四元数这个概念虽然重要,但是很少会在通识教育课程中涉及到,更多的是一些图形学或者是工程学当中才会进行讲解.本 ...

  9. 2.第一篇 k8s组件版本及功能简介

    文章转载自:https://mp.weixin.qq.com/s?__biz=MzI1MDgwNzQ1MQ==&mid=2247483772&idx=1&sn=a693d8a9 ...

  10. 使用Docker Compose部署SpringCloud项目docker-compose.yml文件示例

    注意各组件之间的依赖关系 microservice-discovery-eureka: image: reg.itmuch.com/microservice-discovery-eureka port ...