
























本系列汇总,请查看这里:https://www.cnblogs.com/uncleyong/p/19503695
源代码:https://github.com/tortoise/tortoise-orm/
Tortoise ORM 是一款为 Python 异步编程(Asyncio)设计的 ORM(对象关系映射)工具,它的设计灵感来自 Django ORM,语法风格也和 Django ORM 非常相似,但完全适配异步场景(比如 FastAPI、Starlette 等异步 Web 框架),可以让你用面向对象的方式操作数据库,无需直接编写 SQL 语句。
简单来说:
参考:https://tortoise.org.cn/getting_started.html
安装 tortoise:pip install tortoise-orm
您还可以使用您的数据库驱动程序进行安装,对于 MySQL:pip install tortoise-orm[asyncmy]
参考:GitHub - tortoise/tortoise-orm: Familiar asyncio ORM for python, built with relations in mind

1.主表
2. 关联表
目录结构

models.py
# 选课
from tortoise import fields
from tortoise.models import Model
class Student(Model):
id = fields.IntField(pk=True, description="主键")
name = fields.CharField(max_length=32, description="姓名")
pwd = fields.CharField(max_length=32, description="密码")
sno = fields.IntField(description="学号")
# 一对多的关系
clas = fields.ForeignKeyField("models.Clas", related_name="students") # 最后数据库中字段是clas_id,如果这里我们直接写成clas_id,最后数据库中是clas_id_id
# 多对多的关系
courses = fields.ManyToManyField("models.Course", related_name="students", description='学生选课表') # 生成的表名是student_course,字段是student_id、course_id
class Course(Model):
id = fields.IntField(pk=True)
name = fields.CharField(max_length=32, description="课程名称")
teacher = fields.ForeignKeyField("models.Teacher", related_name='courses', description='课程讲师表')
# addr = fields.CharField(max_length=32, description="教室", default="")
# desc = fields.CharField(max_length=32, description="教室信息", default="")
class Clas(Model):
id = fields.IntField(pk=True)
name = fields.CharField(max_length=32, description="班级名称")
class Teacher(Model):
id = fields.IntField(pk=True)
name = fields.CharField(max_length=32, description="姓名")
pwd = fields.CharField(max_length=32, description="密码")
tno = fields.IntField(description="老师编号")
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。