gpt4 book ai didi

python - 防止代码在 syncdb 期间运行

转载 作者:太空宇宙 更新时间:2023-11-04 08:23:22 26 4
gpt4 key购买 nike

我有一些抛出的代码导致 syncdb 抛出错误(因为它试图在创建表之前访问模型)。

有没有办法让代码不在 syncdb 上运行?像这样的东西:

if not syncdb:
run_some_code()

谢谢:)

编辑:PS - 我考虑过使用 post_init 信号...作为访问数据库的代码,这是个好主意吗?

更多信息

这里有一些要求的更多信息:)

我遇到过几次,例如...我在 django-cron 上进行黑客攻击,并确定有必要确保在加载 django 时不存在现有作业(因为它会搜索所有已安装的应用程序作业并在加载时添加它们)。

所以我在__init__.py 文件的顶部添加了以下代码:

import sqlite3

try:
# Delete all the old jobs from the database so they don't interfere with this instance of django
oldJobs = models.Job.objects.all()
for oldJob in oldJobs:
oldJob.delete()
except sqlite3.OperationalError:
# When you do syncdb for the first time, the table isn't
# there yet and throws a nasty error... until now
pass

出于显而易见的原因,这是废话。它与 sqlite 相关联,我有更好的地方可以放置此代码(这正是我遇到这个问题的方式)但它有效。

如您所见,您得到的错误是操作错误(在 sqlite 中),堆栈跟踪显示类似“未找到表 django_cron_job”的内容

解决方案

最后,目标是在加载任何页面之前运行一些代码

这可以通过在 urls.py 文件中执行它来完成,因为它必须在可以提供页面之前导入(显然)。

而且我能够删除那个丑陋的 try/except block :) 感谢上帝(和 S. Lott)

最佳答案

“编辑:PS - 我考虑过使用 post_init 信号...作为访问数据库的代码,这是个好主意吗?”

从不。

如果您有在创建表之前访问模型的代码,那么您会遇到很大很大的问题。您可能正在做一些严重错误的事情。

通常,您大约运行一次 syncdb。数据库已创建。您的网络应用程序使用数据库。

有时,您会更改设计、删除并重新创建数据库。然后您的 Web 应用程序会长时间使用该数据库。

您(通常)不需要 __init__.py 模块中的代码。您应该(几乎)永远不会拥有在 __init__.py 模块中执行实际工作的可执行代码。这是非常非常罕见的,不适合 Django。

我不确定你为什么在 Django Cron 时搞乱 __init__.py表示您在 urls.py 中安排日程安排。


编辑

清除记录是一回事。

乱用 __init__.py 和 Django-cron 的 base.py 显然是完全错误的方法。如果有那么复杂,那是你做错了。

不可能说出你想做什么,但它应该是微不足道的。

您的 urls.py 只能在 syncdb 之后以及所有 ORM Material 都已正确配置和绑定(bind)之后运行。

例如,您的 urls.py 可以删除一些行,然后将一些行添加到表中。至此,所有 syncdb 问题都解决了。

为什么你的逻辑不在 urls.py 中?

关于python - 防止代码在 syncdb 期间运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/937316/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com