zoukankan      html  css  js  c++  java
  • Sanic二十一:Sanic + tortoise-orm 之模型定义

    Tortoise ORM 是异步的ORM,设计灵感来自 Django,官网:https://tortoise.github.io/

    Tortoise ORM 目前支持以下数据库 :
      1、PostgreSQL >= 9.4,使用asyncpg
      2、SQLite,使用aiosqlite
      3、MySQL/MariaDB,使用aiomysql或asyncmy

    此时的最新版本:0.17.6

    要求:python版本  >= 3.7

    安装:pip install tortoise-orm

    使用示例:

    定义模型:需从tortoise引入Model类,然后所有模型都继承于Model即可,然后引入fields,fields模块提供了非常多的数据类型提供使用

    然后使用官方提供的 register_tortoise 绑定 sanic 的实例 app 即可

    register_tortoise 支持的参数

    app: Sanic实例
    config: 字典格式的配置
    config_file: 配置文件路径
    db_url: 数据库连接信息
    modules: 字典的形式指定模型,可分组,指定模型所在的py文件,放在list中
    generate_schemas: 为True则立即生成表信息

    config示例:

    {
    'connections': {
    # Dict format for connection
    'default': {
    'engine': 'tortoise.backends.asyncpg',
    'credentials': {
    'host': 'localhost',
    'port': '5432',
    'user': 'tortoise',
    'password': 'qwerty123',
    'database': 'test',
    }
    },
    # Using a DB_URL string
    'default': 'postgres://postgres:qwerty123@localhost:5432/events'
    },
    'apps': {
    'user_info': {
    'models': ['user', 'role'],
    'default_connection': 'default',
    },
            'job_info': {
    'models': ['project', 'job'],
    'default_connection': 'default',
    }

    }

    这里需要注意的是,models参数,支持用模型分组

    第一种,只定义一个模型分组,名字是models,对应的模型所在的位置list:project.py,user.py

    运行即可生成数据表

    第二种,模型可以分组,当在模型映射关系的时候,需要使用 分组名.模型(详见后续文章)

    user.py

    from tortoise import Model, fields


    class Users(Model):
    id = fields.IntField(pk=True)
    name = fields.CharField(50)

    project.py

    from tortoise import Model, fields


    class Project(Model):
    id = fields.BigIntField(pk=True)
    name = fields.CharField(50)
    task = fields.CharField(50)

    main.py

    from sanic import Sanic, response
    from tortoise.contrib.sanic import register_tortoise

    from user import Users

    app = Sanic(__name__)


    @app.route("/")
    async def user_list(request):
    users = await Users.all()
    return response.json({"users": [str(user) for user in users]})


    # # 第一种,只定义一个模型分组,名字是models,对应的模型所在的位置list:project.py,user.py
    # register_tortoise(
    # app,
    # db_url="mysql://root:123456@localhost:3306/test?charset=utf8mb4", # MySQL
    # # db_url="sqlite://db.sqlite3", # sqlite
    # modules={"models": ["project", "user"]},
    # generate_schemas=True # 启动时生成表
    # )

    # 第二种,根据模型的类型分组,各自指定自己对应的模型所在的位置list:project.py,user.py
    register_tortoise(
    app,
    db_url="mysql://root:123456@localhost:3306/test?charset=utf8mb4", # MySQL
    modules={
    "user_info": ["user"],
    "job_info": ["project"]
    },
    generate_schemas=True # 启动时生成表
    )

    if __name__ == '__main__':
    import uvicorn

    uvicorn.run('main:app', host='0.0.0.0', port=8000, debug=True)
    讨论群:249728408
  • 相关阅读:
    Git轻松入门3:远程仓库篇
    Git轻松入门2:分支篇
    Git轻松入门1:本地仓库篇
    通俗易懂的解释:什么是API
    小白都看得懂的Javadoc使用教程
    尾调用与尾递归
    要理解递归就要先理解递归:手把手教你写递归
    不复杂的空间复杂度
    不复杂的时间复杂度
    Java程序执行过程及内存机制
  • 原文地址:https://www.cnblogs.com/zhongyehai/p/15178002.html
Copyright © 2011-2022 走看看