- 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/
我在我的盒子上安装了 Tortoise Hg(mercurial)。然后我在同一个盒子上安装了 Tortoise SVN。当我转到一个文件夹并尝试鼠标右键时,我看到“Tortoise Hg”的菜单条目
我不小心删除了一些文件并提交了。 所以我需要删除那个修订版。 否则,每当我更新修订版时,我的文件都会被删除 最佳答案 通常您不能在 svn 中删除修订。您只能提交新修订以恢复以前的更改。 您需要将旧版
有没有人有过在乌龟中移动文件并成功提交,只是后来提交了不同的更改并被告知树冲突的经历: 原始位置的文件已被删除,但在乌龟中被标记为丢失 新位置的文件在那里,但标记为已添加。 (我用的是tortoise
我正在尝试使用 Subversion 存储库设置我的家庭服务器(经过一些更改)。 我在 Windows Server 2003 服务器机器上卸载并重新安装了 VisualSVN 服务器,存储库的地址(
在 Clearcase 中,我可以为给定的一组文件生成一个“标签”,并始终返回到该标签以重新生成所有文件,就像我生成标签时一样。 我如何在 Subversion 中执行此操作?我正在使用 Tortoi
我的本地计算机上的Tortoise SVN出现问题。我尝试创建存储库文件夹,并收到一条消息: Subversion reported an error while creating a reposit
我刚刚在我的 .NET 解决方案中添加了一个类库项目。当我构建它时,它创建了 bin和 obj我想从版本控制中排除的文件夹。 但是,Tortoise 不会让我在第一次提交之前忽略这些文件夹。它给出了以
我已经在本地 checkout 了 SVN 分支(我的分支)的副本,我从另一个分支(具有完全不同的文件夹结构)合并到该副本。所以基本上有很多删除(旧文件)和添加(新文件)。 当我尝试将合并提交到存储库
问题:最近,如果我将新文件添加到 checkout 的存储库,添加的文件默认会被忽略,并且不会在提交期间显示在文件列表中。 重现: 1) 在 checkout 的文件夹中创建一个新文件。 2) 文件上
哎呀,我需要从我删除的文件中获取一些信息,不久前。在 CVS 中,我只会去 ATTIC 找到它,我如何在 SVN 中找到一个文件,而不必返回到它存在的修订版(特别烦人,因为我真的不知道我何时删除 -
我正在尝试在用户不是管理员的 Windows PC 上安装 TortoiseSVN(版本:1.6.1.16129)。 安装程序是一个 msi 文件,默认情况下没有“运行方式”选项。 我都试过了: ms
我的 Tortoise SVN 图标正确显示在我本地 C:\驱动器上的文件夹中。但是,我存储在映射驱动器上的文件夹没有显示任何图标覆盖。我仍然可以在 map 驱动器上 checkout 、更新等,因此
在一个项目中,我找不到一个文件。我想该文件在某个修订版中被删除了。 我只知道文件名。可以用 Tortoise SVN 客户端找到这个文件吗? 最佳答案 如果您知道它所在的目录,您可以右键单击该目录,然
我有以下使用 fastapi 的实现。 我目前的问题是,我终生无法对乌龟模型执行 early init 以将关系恢复到模式中。 我试过基本上在所有地方转储以下行,但它似乎不起作用。 Tortoise.
我有一个版本化的 .cpp 文件,我想看看谁写了某行代码,所以我使用了 Tortoise SVN 责备选项。但是当它打开文件时,它显示的是: 有没有人遇到过这个问题? 附言 我正在使用 Tortois
我的存储库中有许多不再需要的项目。 我从存储库中删除了它们 - 这似乎是将它们从 SVN 控件中删除,因为 Windows 资源管理器中的相关图标消失了,文件夹现在显示为标准的 Windows 文件夹
我的机器上有一个文件夹,但我故意与主项目不同步(我应该分支,但没有) 我现在已经将这个文件夹更新到最新版本,忘记了我不应该这样做。 是否可以撤消此更新,并回到更新前的状态? 或者,(当我关闭更新窗口时
是否可以更改 Tortoise SVN 的上下文菜单,以便我更频繁使用的某些命令在菜单中显示更高一级? 例如,右键单击资源管理器中的文件夹,您会看到这些选项 SVN Update SVN Commit
我在这方面遇到了很大的问题。 我想从 中取出我的整个项目根文件夹,并将其移动到 root/webUI 文件夹。 我所做的看起来很简单,但它不起作用。我只是做了新的 root/webUI 文件夹,选择
我正在使用 tortoise 客户端的 Windows 下工作,并进行了大量更改,包括许多删除、添加等。当我尝试提交时,出现以下错误,但我无法确定哪个目录是问题的根源? 不能以非递归方式提交具有子节点
我是一名优秀的程序员,十分优秀!