- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下使用 fastapi 的实现。
我目前的问题是,我终生无法对乌龟模型执行 early init
以将关系恢复到模式中。
我试过基本上在所有地方转储以下行,但它似乎不起作用。
Tortoise.init_models(["models.user", "models.group"], "models")
我也尝试过以这种方式使用 prefetch_related
但这也不起作用
GetGroup.from_queryset(Group.get(id=3).prefetch_related('owner'))
我已经在谷歌上搜索了几个小时,但没有找到一个具体的答案/方法来让它正常工作。
文件夹结构:
app
│ main.py
└───database
│ │ database.py
└───models
| │ user.py
| │ group.py
└───routers
| │ user_router.py
| │ group_router.py
└───services
| │ auth.py
主程序
from fastapi import FastAPI
from database.database import init_db
from routers.user_router import router as UserRouter
from routers.group_router import router as GroupRouter
# Instantiate the Application
app = FastAPI(title="test", root_path="/api/")
# Include the Routers
app.include_router(UserRouter, tags=["User"], prefix="/user")
app.include_router(GroupRouter, tags=["Group"], prefix="/group")
# Start DB Connection on Startup
@app.on_event("startup")
async def startup_event():
init_db(app)
数据库/数据库.py
from decouple import config
from fastapi import FastAPI
from tortoise import Tortoise
from tortoise.contrib.fastapi import register_tortoise
def init_db(app: FastAPI) -> None:
Tortoise.init_models(["models.user", "models.group"], "models")
register_tortoise(
app,
db_url=f"mysql://{config('MYSQL_USER')}:{config('MYSQL_PASSWORD')}@{config('MYSQL_HOST')}:{config('MYSQL_EXPOSE')}/{config('MYSQL_DB')}",
modules={"models": ["models.user",
"models.group",
]},
generate_schemas=False,
add_exception_handlers=True,
)
TORTOISE_ORM = {
"connections": {"default": f"mysql://{config('MYSQL_USER')}:{config('MYSQL_PASSWORD')}@{config('MYSQL_HOST')}:{config('MYSQL_EXPOSE')}/{config('MYSQL_DB')}"},
"apps": {
"models": {
"models": ["models.user",
"models.group",
"aerich.models"],
"default_connection": "default",
},
},
}
模型/用户.py
from tortoise import fields
from tortoise.models import Model
from tortoise.contrib.pydantic import pydantic_model_creator
from models.group import Group
class User(Model):
# ##### Define Readonly Fields ##### #
id = fields.BigIntField(pk=True)
# ##### Define Normal Fields ##### #
first_name = fields.CharField(max_length=50)
last_name = fields.CharField(max_length=50)
username = fields.CharField(max_length=50, unique=True)
email = fields.CharField(max_length=50, unique=True)
password = fields.CharField(max_length=128)
# ##### Define O2M ##### #
owned_groups: fields.ReverseRelation[Group]
# ##### Define M2M ##### #
groups: fields.ManyToManyRelation[Group]
# ##### Define Time_Stamps ###### #
created_at = fields.DatetimeField(auto_now_add=True)
modified_at = fields.DatetimeField(auto_now=True)
class Meta:
table: str = 'users'
AuthData = pydantic_model_creator(User)
CreateUser = pydantic_model_creator(User, name="CreateUser", exclude_readonly=True)
UpdateUser = pydantic_model_creator(User, name="UpdateUser", exclude_readonly=True, exclude=['password'])
GetUser = pydantic_model_creator(User, name="GetUser", exclude=['password'])
ChangeUserPassword = pydantic_model_creator(User, name="ChangeUserPassword", exclude_readonly=True, include=['password'])
模型/group.py
from tortoise import fields
from tortoise.models import Model
from tortoise.contrib.pydantic import pydantic_model_creator
class Group(Model):
# ##### Define Readonly Fields ##### #
id = fields.BigIntField(pk=True)
# ##### Define Normal Fields ##### #
name = fields.CharField(max_length=50, unique=True)
# ##### Define O2M ##### #
owner = fields.ForeignKeyField("models.User", related_name="owned_groups")
# ##### Define M2M ##### #
members = fields.ManyToManyField("models.User", related_name="groups")
# ##### Define Time_Stamps ###### #
created_at = fields.DatetimeField(auto_now_add=True)
modified_at = fields.DatetimeField(auto_now=True)
class Meta:
table: str = 'groups'
CreateGroup = pydantic_model_creator(Group, name="CreateGroup", exclude_readonly=True, exclude=['members'])
UpdateGroup = pydantic_model_creator(Group, name="UpdateGroup", exclude_readonly=True, exclude=['members'])
GetGroup = pydantic_model_creator(Group, name="GetGroup")
路由器/group_router.py
from typing import List
import json
from fastapi import HTTPException, APIRouter, Depends, status
from models.user import User
from models.group import Group, CreateGroup, UpdateGroup, GetGroup
from tortoise.contrib.fastapi import HTTPNotFoundError
from services.auth import current_user
# Intialize Router
router = APIRouter()
# ###################### Define Routes ###################### #
# Create A Group
@router.post("/", dependencies=[Depends(current_user)])
async def create_group(group: CreateGroup, user: User = Depends(current_user)):
user = await user
try:
await Group.create(**group.dict(exclude_unset=True), owner_id=user.id)
except Exception:
raise HTTPException(
status_code=status.HTTP_422_UNPROCESSABLE_ENTITY,
detail="Group Name Already Exists"
)
return {"Group Created Successfully"}
# Update A Group
@router.put("/{group_id}", dependencies=[Depends(current_user)], responses={404: {"model": HTTPNotFoundError}})
async def update_group(group_id: int, group: UpdateGroup, user: User = Depends(current_user)):
user = await user
group = await GetGroup.from_queryset_single(Group.get(id=group_id))
return group
if user.id == group.id:
await Group.filter(id=group_id).update(**group.dict(exclude_unset=True))
return {"Group Successfully Updated"}
else:
raise HTTPException(
status_code=status.HTTP_406_NOT_ACCEPTABLE,
detail="You can't edit a group unless you're the owner"
)
# Get All Groups
@router.get("/", dependencies=[Depends(current_user)])
async def get_groups():
return GetGroup.schema()
如您所见,最后一行 GetGroup.schema()
永远不会返回关系。
我尝试在容器启动时捕获日志并得到以下信息
[2021-04-24 19:59:53 +0000] [1255] [INFO] Started server process [1255]
[2021-04-24 19:59:53 +0000] [1255] [INFO] Waiting for application startup.
[2021-04-24 19:59:53 +0000] [1255] [ERROR] Traceback (most recent call last):
File "/usr/local/lib/python3.8/site-packages/tortoise/__init__.py", line 358, in _discover_models
module = importlib.import_module(models_path)
File "/usr/local/lib/python3.8/importlib/__init__.py", line 127, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "<frozen importlib._bootstrap>", line 1014, in _gcd_import
File "<frozen importlib._bootstrap>", line 991, in _find_and_load
File "<frozen importlib._bootstrap>", line 973, in _find_and_load_unlocked
ModuleNotFoundError: No module named 'a'
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/usr/local/lib/python3.8/site-packages/starlette/routing.py", line 526, in lifespan
async for item in self.lifespan_context(app):
File "/usr/local/lib/python3.8/site-packages/starlette/routing.py", line 467, in default_lifespan
await self.startup()
File "/usr/local/lib/python3.8/site-packages/starlette/routing.py", line 502, in startup
await handler()
File "/app/main.py", line 17, in startup_event
init_db(app)
File "/app/database/database.py", line 8, in init_db
Tortoise.init_models("app.models.user", "models")
File "/usr/local/lib/python3.8/site-packages/tortoise/__init__.py", line 415, in init_models
app_models += cls._discover_models(models_path, app_label)
File "/usr/local/lib/python3.8/site-packages/tortoise/__init__.py", line 360, in _discover_models
raise ConfigurationError(f'Module "{models_path}" not found')
tortoise.exceptions.ConfigurationError: Module "a" not found
[2021-04-24 19:59:53 +0000] [1255] [ERROR] Application startup failed. Exiting.
请注意,它会这样做几秒钟,然后应用程序会正确启动,我也尝试过将 pydantic 模型创建分离到一个名为“schema”的单独文件夹中,但也没有做任何事情
最佳答案
所以我终于找到了答案,我会把它留在这里以防一些可怜的人偶然发现这个问题
诀窍在于移动
from database.database import init_db
到main.py
文件的顶部
并添加
Tortoise.init_models(["models.user", "models.group"], "models")
在 init_db() 函数下面,以便在 register_tortoise
函数执行和所有模型初始化之前调用它
关于python - Fastapi/Tortoise 早期模型初始化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67257307/
我是 Spring 新手,这就是我想要做的事情: 我正在使用一个基于 Maven 的库,它有自己的 Spring 上下文和 Autowiring 字段。 它的bean配置文件是src/test/res
我在我的测试脚本中有以下列表初始化: newSequenceCore=["ls", "ns", "*", "cm", "*", "ov", "ov", "ov", "ov", "kd"] (代表要在控
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Class construction with initial values 当我查看 http://en.
我得到了成员变量“objectCount”的限定错误。编译器还返回“ISO C++ 禁止非常量静态成员的类内初始化”。这是主类: #include #include "Tree.h" using n
我有如下所示的a.h class A { public: void doSomething()=0; }; 然后我有如下所示的b.h #include "a.h" class b: publi
我需要解析 Firebase DataSnapshot (一个 JSON 对象)转换成一个数据类,其属性包括 enum 和 list。所以我更喜欢通过传递 DataSnapshot 来手动解析它进入二
我使用 JQuery 一段时间了,我总是使用以下代码来初始化我的 javascript: $(document).ready( function() { // Initalisation logic
这里是 Objective-C 菜鸟。 为什么会这样: NSString *myString = [NSString alloc]; [myString initWithFormat:@"%f", s
我无法让核心数据支持的 NSArrayController 在我的代码中正常工作。下面是我的代码: pageArrayController = [[NSArrayController alloc] i
我对这一切都很陌生,并且无法将其安装到我的后端代码中。它去哪里?在我的页脚下面有我所有的 JS? 比如,这是什么意思: Popup initialization code should be exec
这可能是一个简单的问题,但是嘿,我是初学者。 所以我创建了一个程序来计算一些东西,它目前正在控制台中运行。我决定向其中添加一个用户界面,因此我使用 NetBeans IDE 中的内置功能创建了一个 J
我有 2 个 Controller ,TEST1Controller 和 TEST2Controller 在TEST2Controller中,我有一个initialize()函数设置属性值。 如果我尝
据我所知, dependentObservable 在声明时会进行计算。但如果某些值尚不存在怎么办? 例如: var viewModel ={}; var dependentObservable1 =
我正在阅读 POODR 这本书,它使用旧语法进行默认值初始化。我想用新语法实现相同的功能。 class Gear attr_reader :chainring, :cog, :wheel de
我按照 polymer 教程的说明进行操作: https://www.polymer-project.org/3.0/start/install-3-0 (我跳过了可选部分) 但是,在我执行命令“po
很抱歉问到一个非常新手的Kotlin问题,但是我正在努力理解与构造函数和初始化有关的一些东西。 我有这个类和构造函数: class TestCaseBuilder constructor(
假设我们有一个包含 30 列和 30 行的网格。 生命游戏规则简而言之: 一个小区有八个相邻小区 当一个细胞拥有三个存活的相邻细胞时,该细胞就会存活 如果一个细胞恰好有两个或三个活的相邻细胞,那么它就
我是 MQTT 和 Android 开放附件“AOA” 的新手。在阅读教程时,我意识到,在尝试写入 ByteArrayOutputStream 类型的变量之前,应该写入 0 或 0x00首先到该变量。
我有 2 个 Controller ,TEST1Controller 和 TEST2Controller 在TEST2Controller中,我有一个initialize()函数设置属性值。 如果我尝
我有一个inotify /内核问题。我正在使用“inotify” Python项目进行观察,但是,我的问题仍然是固有的关于inotify内核实现的核心。 Python inotify项目处理递归ino
我是一名优秀的程序员,十分优秀!