- models:比如有以下三個模型
from django.db import models
"""
基類,其他類繼承即可獲得對應的欄位
"""
class BaseModel(models.Model):
updated_tm = models.DateTimeField(auto_now=True)
created_tm = models.DateTimeField(auto_now_add=True)
class Meta:
abstract = True
"""
專案串列
"""
class ProjectList( BaseModel):
project_id = models.AutoField(help_text="專案ID", primary_key=True)
project_name = models.SlugField(max_length=128, help_text="專案名稱", unique=True)
class Meta:
db_table = 'project_list'
verbose_name = '專案串列資訊'
verbose_name_plural = verbose_name
"""
專案詳情
"""
class ProjectDetail(BaseModel):
project_introduction = models.CharField(max_length=128, help_text="用戶簡介")
project_info = models.ForeignKey(to=ProjectList, on_delete=models.DO_NOTHING, db_constraint=False, related_name='user')
class Meta:
db_table = project_detail'
verbose_name = '專案詳情資訊'
verbose_name_plural = verbose_name
一、同時新增資料到兩個資料庫表
- views
from rest_framework import filters, mixins, generics
from rest_framework.viewsets import GenericViewSet
class ProjectListView(mixins.CreateModelMixin, GenericViewSet):
queryset = Account.objects.filter(is_delete=0).all().order_by("-created_tm")
def create(self, request, *args, **kwargs):
# 先定義兩個dict
project_list_dict = {}
project_detail_dict = {}
# 使用 ._meta.get_fields() 獲取資料庫表的全部欄位,再使用field.name獲取全部的欄位名稱,放入各自的dict,不存在的自動忽略掉
for item in request.data.items():
if item in [field.name for field in ProjectList._meta.get_fields()]:
project_list_dict [item[0]] = item[1]
elif item in [field.name for field in ProjectDetail._meta.get_fields()]:
project_detail_dict [item[0]] = item[1]
# 從上面的models可以看到,專案詳情與專案串列兩張表是有關聯的,所以,新增資料的時候,先現在串列,新增成功,生成ID后,再新增詳情,并通過ID與串列資料關聯起來
# 檢查專案是否存在,專案名稱唯一約束,Serializer內設定必填
try:
# 存在就直接失敗
ProjectList.objects.get(project_name=request.data.get('project_ame'))
return xxx
except Account.DoesNotExist:
# 如果不存在,先呼叫ProjectList表新增資料
try:
project_create = ProjectList.objects.update_or_create(defaults=project_list_dict, project_name=project_list_dict["project_ame"])
# 如果ProjectList表新增資料成功,則通過project_info,在ProjectDetail新增對應的資料
if project_create:
project_id = ProjectList.objects.filter(project_name=project_list_dict["project_ame"]).values('project_id').first()
ProjectDetail.objects.update_or_create(defaults=project_detail_dict, project_info=project_id["project_id"])
return xxx
except Exception as e:
return e
二、同時回傳兩個表的資料(插拔式)
- 插拔式的好處:即插即用,需要時才呼叫,不需要則不呼叫
- 從ProjectDetail這個models我們可以看到,是沒有定義project_id和project_name的,但我們是與ProjectList關聯的,所以,我們可以通過project_info,回傳ProjectList已定義的project_id和project_name
# 我們只需要把ProjectDetail改成以下這樣子就可以了
class ProjectDetail(BaseModel):
project_introduction = models.CharField(max_length=128, help_text="用戶簡介")
project_info = models.ForeignKey(to=ProjectList, on_delete=models.DO_NOTHING, db_constraint=False, related_name='user')
class Meta:
db_table = project_detail'
verbose_name = '專案詳情資訊'
verbose_name_plural = verbose_name
@property
def project_id(self):
return self.project_info.project_id
@property
def project_name(self):
return self.project_info.project_name
# 然后在序列化器內直接呼叫project_id和project_name即可
class ProjectDetailSerializer(serializers.ModelSerializer):
class Meta:
model = ProjectDetail
fields = ('project_id', 'project_name', 'project_introduction',)
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/518830.html
標籤:Python
上一篇:python基礎-集合的常用操作
