[英]Django - multi-table inheritance - convert Parent to Child
我有看起来像这样的模型:
class Property(Model):
...
class Meta:
# not abstract
class Flat(Property):
...
class House(Property):
...
是否可以将现有的Property
转换为House
或Flat
? 我知道House
或Flat
附加字段位于不同的表中,所以这应该可以通过创建这样的行并建立一些关系来实现。
我怎样才能做到这一点?
使用自定义方法?
class Property(...):
...
def convert_to_house(self):
# create a house
house = House.objects.create(
...
)
# delete current property:
self.delete()
由于多种原因,创建新House
并删除Property
并不是一个好方法。 其中之一是Property
对象可能已经涉及与其他模型/对象的关系。
这看起来对我有用:
child = House(property_ptr=property, created=now())
child.save()
作为 DRF 自定义操作,它看起来像这样:
@action(['POST'], detail=True, url_path='create-child')
def create_child(self, request, pk=None):
property = self.get_object()
if property.get_child():
raise APIException(detail="Blah blah")
_type = request.data.get('type')
try:
ChildModel = Property.get_subtypes_map()[_type]
except KeyError:
raise APIException(detail="Blah blah")
child = ChildModel(property_ptr=property, created=now())
child.save()
return Response({'id':child.id})
PS:您还应该检查模型是否已经有任何孩子。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.