- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了一个有点难以解释的问题,所以请多多包涵。首先,以下是相关版本,以防万一:Django 2.0.3、Python 3.6.4、PostgreSQL 10.3。
基本上,我的一些 Django 模型有这个结构:
class Capability(models.Model):
relationships = models.ManyToManyField('self',
symmetrical=False,
through='CapabilityRelationship',
blank=True)
name = models.CharField(max_length=255)
class CapabilityRelationship(models.Model):
from_capability = models.ForeignKey(Capability,
on_delete=models.CASCADE,
related_name='from_set',
blank=True,
null=True)
to_capability = models.ForeignKey(Capability,
on_delete=models.CASCADE,
related_name='to_set')
number = models.PositiveSmallIntegerField(validators=[MinValueValidator(1)])
def _get_complete_numbers(self):
# generate the complete numbers using depth-first search
def save(self, *args, **kwargs):
# Get the complete numbers before saving. If we're not able to generate the complete numbers, something is
# wrong, an error will be raised, and we don't want to save.
complete_numbers = self._get_complete_numbers()
super().save(*args, **kwargs) # Call the "real" save() method.
# Delete all old complete numbers.
self.capabilityrelationshipcompletenumber_set.all().delete()
# Save the new complete numbers.
for complete_number in complete_numbers:
CapabilityRelationshipCompleteNumber.objects.create(capability_relationship=self,
complete_number=complete_number)
class CapabilityRelationshipCompleteNumber(models.Model):
capability_relationship = models.ForeignKey(CapabilityRelationship, on_delete=models.CASCADE)
complete_number = models.CharField(max_length=255, unique=True)
为了用文字描述这些模型,我有一个Capability
模型,它与自身具有多对多关系(在CapabilityRelationship
中捕获)。实际上,这将是一棵“树”,其中每个节点可以有多个子节点 和 多个父节点(即,它是一个有向无环图)。最后,每个关系实例可以有多个“完整数字”(在 CapabilityRelationshipCompleteNumber
中捕获)。
“数字”和“完整数字”背后的思想本质上是杜威十进制系统。完整数量的 1.2.3.4 将具有 4 个级别的 Capability
对象,其中 1 是最顶层(即根节点),4 是叶子。因为我在上面布置的结构是一个 DAG 而不是一棵树,一个节点实际上可以有多个这些“完整”数字,因为从任何给定节点到它的根可以有多条路径。
如果此描述不成立,请告诉我,我可以在 Paint 中模拟一些东西。
我正在重写 CapabilityRelationship.save()
方法,因为每次关系更改时我都需要重新计算完整的数字,因为 number
可能已经更改。所以我想做的就是简单地计算新的完整数字,删除所有旧的完整数字,然后保存新的完整数字。
我遇到的问题是我根本无法删除旧的完整数字,这让我感到莫名其妙。我想知道是否有关于重写 CapabilityRelationship.save()
的东西,我根本没有得到。例如:
def save(self, *args, **kwargs):
complete_numbers = self._get_complete_numbers()
print('complete numbers: {}'.format(complete_numbers))
super().save(*args, **kwargs) # Call the "real" save() method.
print('before delete: {}'.format(self.capabilityrelationshipcompletenumber_set.all()))
self.capabilityrelationshipcompletenumber_set.all().delete()
print('after delete: {}'.format(self.capabilityrelationshipcompletenumber_set.all()))
for complete_number in complete_numbers:
CapabilityRelationshipCompleteNumber.objects.create(capability_relationship=self,
complete_number=complete_number)
print('after save: {}'.format(self.capabilityrelationshipcompletenumber_set.all()))
如果我访问管理站点并将叶节点的 number
设置为 1,保存它,然后将其修改为 2,我得到以下输出:
complete numbers: {'1.2.1.1', '2.2.1.1', '1.3.1.1', '1.1.1.1'}
before delete: <QuerySet []>
after delete: <QuerySet []>
after save: <QuerySet [<CapabilityRelationshipCompleteNumber: 1.1.1.1>, <CapabilityRelationshipCompleteNumber: 1.2.1.1>, <CapabilityRelationshipCompleteNumber: 1.3.1.1>, <CapabilityRelationshipCompleteNumber: 2.2.1.1>]>
complete numbers: {'1.1.1.2', '1.2.1.2', '2.2.1.2', '1.3.1.2'}
before delete: <QuerySet [<CapabilityRelationshipCompleteNumber: 1.1.1.1>, <CapabilityRelationshipCompleteNumber: 1.2.1.1>, <CapabilityRelationshipCompleteNumber: 1.3.1.1>, <CapabilityRelationshipCompleteNumber: 2.2.1.1>]>
after delete: <QuerySet []>
after save: <QuerySet [<CapabilityRelationshipCompleteNumber: 1.1.1.2>, <CapabilityRelationshipCompleteNumber: 1.2.1.2>, <CapabilityRelationshipCompleteNumber: 1.3.1.2>, <CapabilityRelationshipCompleteNumber: 2.2.1.2>]>
现在,所有这些看起来都很棒,但是当我访问管理站点以获取所有完整数字的列表时,我看到到目前为止计算的所有 8 个完整数字,而不是更改后当前正确的 4 个number
到 2。如果我打开 Python shell 并列出完整的数字,我会看到到目前为止创建的所有数字:
> ./manage.py shell
Python 3.6.4 (default, Dec 19 2017, 15:24:51)
[GCC 4.2.1 Compatible Apple LLVM 9.0.0 (clang-900.0.39.2)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
(InteractiveConsole)
>>> from src.apps.api.models.capability import *
>>> CapabilityRelationshipCompleteNumber.objects.all()
<QuerySet [<CapabilityRelationshipCompleteNumber: 1.1.1.1>, <CapabilityRelationshipCompleteNumber: 1.1.1.2>, <CapabilityRelationshipCompleteNumber: 1.2.1.1>, <CapabilityRelationshipCompleteNumber: 1.2.1.2>, <CapabilityRelationshipCompleteNumber: 1.3.1.1>, <CapabilityRelationshipCompleteNumber: 1.3.1.2>, <CapabilityRelationshipCompleteNumber: 2.2.1.1>, <CapabilityRelationshipCompleteNumber: 2.2.1.2>]>
如果我使用 psql 直接查看数据库,我会看到同样的事情。
显然,无论出于何种原因,删除调用实际上并未发生。我尝试了 CapabilityRelationshipCompleteNumber.objects.filter(capability_relationship=self).delete()
、CapabilityRelationshipCompleteNumber.objects.all().delete()
,并发出了原始 SQL DELETE FROM api_capabilityrelationshipcompletenumber;
使用 connection.cursor()
。似乎什么都不起作用。我不明白这是怎么回事。我已阅读有关删除 QuerySet 和覆盖 save()
的 Django 文档,但我没有看到任何可以帮助我诊断问题的内容。
有人知道这是怎么回事吗?任何帮助是极大的赞赏。如果我可以澄清任何一个,请告诉我。
最佳答案
好吧,我调试了一整天在互联网上翻来覆去地想出来了。据我所知,问题似乎在于 Django 如何保存 ManyToMany 关系。正如在 https://stackoverflow.com/a/1925784/1269634 中讨论的那样:
When you save a model via admin forms it's not an atomic transaction. The main object gets saved first (to make sure it has a PK), then the M2M is cleared and the new values set to whatever came out of the form. So if you are in the save() of the main object you are in a window of opportunity where the M2M hasn't been updated yet. In fact, if you try to do something to the M2M, the change will get wiped out by the clear(). I ran into this about a year ago.
虽然这篇文章最初可以追溯到 2009 年,但这种烦恼显然在今天的 Django 2.0 中仍然存在。读完这篇文章后,我相信这就是造成这种怪异的原因。不幸的是,据我所知,这在 Django 文档的任何地方都没有记录,这就是为什么花了这么长时间来追踪和修复。
事实证明,此问题的修复相对简单。我有效地将 CapabilityRelationship.save()
重命名为 CapabilityRelationship.update_complete_numbers()
。然后,我修改了 Capability
管理实现以覆盖 ModelAdmin.save_related()
.管理实现现在看起来像这样:
@admin.register(Capability)
class CapabilityAdmin(nested_admin.NestedModelAdmin):
list_display = ['name']
search_fields = ['name']
inlines = [CapabilityRelationshipInlineAdmin]
def save_related(self, request, form, formsets, change):
super().save_related(request, form, formsets, change)
for capability_relationship in form.instance.to_set.all():
capability_relationship.update_complete_numbers()
这行得通!神奇的是,更新完整的数字发生在模型保存完全完成之后(当 super().save_related(request, form, formsets, change)
返回时为真) ).
感谢大家的帮助!我希望这最终可以帮助其他人。
关于python - 从 model.save() 中删除关联的模型实例不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49605789/
可不可以命名为MVVM模型?因为View通过查看模型数据。 View 是否应该只与 ViewModelData 交互?我确实在某处读到正确的 MVVM 模型应该在 ViewModel 而不是 Mode
我正在阅读有关设计模式的文章,虽然作者们都认为观察者模式很酷,但在设计方面,每个人都在谈论 MVC。 我有点困惑,MVC 图不是循环的,代码流具有闭合拓扑不是很自然吗?为什么没有人谈论这种模式: mo
我正在开发一个 Sticky Notes 项目并在 WPF 中做 UI,显然将 MVVM 作为我的架构设计选择。我正在重新考虑我的模型、 View 和 View 模型应该是什么。 我有一个名为 Not
不要混淆:How can I convert List to Hashtable in C#? 我有一个模型列表,我想将它们组织成一个哈希表,以枚举作为键,模型列表(具有枚举的值)作为值。 publi
我只是花了一些时间阅读这些术语(我不经常使用它们,因为我们没有任何 MVC 应用程序,我通常只说“模型”),但我觉得根据上下文,这些意味着不同的东西: 实体 这很简单,它是数据库中的一行: 2) In
我想知道你们中是否有人知道一些很好的教程来解释大型应用程序的 MVVM。我发现关于 MVVM 的每个教程都只是基础知识解释(如何实现模型、 View 模型和 View ),但我对在应用程序页面之间传递
我想realm.delete() 我的 Realm 中除了一个模型之外的所有模型。有什么办法可以不列出所有这些吗? 也许是一种遍历 Realm 中当前存在的所有类型的方法? 最佳答案 您可以从您的 R
我正在尝试使用 alias 指令模拟一个 Eloquent 模型,如下所示: $transporter = \Mockery::mock('alias:' . Transporter::class)
我正在使用 stargazer 创建我的 plm 汇总表。 library(plm) library(pglm) data("Unions", package = "pglm") anb1 <- pl
我读了几篇与 ASP.NET 分层架构相关的文章和问题,但是读得太多后我有点困惑。 UI 层是在 ASP.NET MVC 中开发的,对于数据访问,我在项目中使用 EF。 我想通过一个例子来描述我的问题
我收到此消息错误: Inceptionv3.mlmodel: unable to read document 我下载了最新版本的 xcode。 9.4 版测试版 (9Q1004a) 最佳答案 您没有
(同样,一个 MVC 验证问题。我知道,我知道......) 我想使用 AutoMapper ( http://automapper.codeplex.com/ ) 来验证我的创建 View 中不在我
需要澄清一件事,现在我正在处理一个流程,其中我有两个 View 模型,一个依赖于另一个 View 模型,为了处理这件事,我尝试在我的基本 Activity 中注入(inject)两个 View 模型,
如果 WPF MVVM 应该没有代码,为什么在使用 ICommand 时,是否需要在 Window.xaml.cs 代码中实例化 DataContext 属性?我已经并排观看并关注了 YouTube
当我第一次听说 ASP.NET MVC 时,我认为这意味着应用程序由三个部分组成:模型、 View 和 Controller 。 然后我读到 NerdDinner并学习了存储库和 View 模型的方法
Platform : ubuntu 16.04 Python version: 3.5.2 mmdnn version : 0.2.5 Source framework with version :
我正在学习本教程:https://www.raywenderlich.com/160728/object-oriented-programming-swift ...并尝试对代码进行一些个人调整,看看
我正试图围绕 AngularJS。我很喜欢它,但一个核心概念似乎在逃避我——模型在哪里? 例如,如果我有一个显示多个交易列表的应用程序。一个列表向服务器查询匹配某些条件的分页事务集,另一个列表使用不同
我在为某个应用程序找出最佳方法时遇到了麻烦。我不太习惯取代旧 TLA(三层架构)的新架构,所以这就是我的来源。 在为我的应用程序(POCO 类,对吧??)设计模型和 DAL 时,我有以下疑问: 我的模
我有两个模型:Person 和 Department。每个人可以在一个部门工作。部门可以由多人管理。我不确定如何在 Django 模型中构建这种关系。 这是我不成功的尝试之一 [models.py]:
我是一名优秀的程序员,十分优秀!