淺談django 模型類使用save()方法的好處與注意事項
阿新 • • 發佈:2020-03-30
如下所示:
def user_degree(self): degree = self.user.update_grade() return degree def save(self,*args,**kwargs): self.degree = self.user_degree() self.p1_user = self.get_p1() self.p2_user = self.get_second() self.p3_user = self.get_third() self.first_get_money = self.get_first_commission() self.second_get_money = self.get_seconds() self.third_get_money = self.get_thirds() self.off_price = self.offPrice() self.need_pay = self.needPay() self.sale_push_money = self.per_sale_money() super(self.__class__,self).save(*args,**kwargs)
在django 的模型類裡,如果有些欄位的值是需要動態生成的,那麼就在模型類裡同樣新增上對應的欄位,並寫上對應的方法,
然後呼叫save()方法,把自定義的方法的結果返回給那個欄位,然後儲存起來。
如果有多個相關聯的欄位都需要動態生成,那麼在save()方法裡的順序就非常重要了,
譬如上面的off_price,need_pay,sale_push_money這三個欄位動態生成的值是有先後關係的,順序錯了,有些生成的結果就不對了。所以一定要注意。
(下面情況如果遇到時再參考即可,表達有點亂,沒有遇到這種情況的可能會感覺莫名其妙,重點是紅色字型部分)
同時,這樣動態填充避免了在欄位中設定外來鍵的弊端(當外來鍵對應的欄位值發生變化時,此模型類裡已經記錄的資料也可能會受到影響,)
尤其是需要記錄消費資訊時,會員的身份變化時,對應的折扣不一樣,當會員身份升級時,如果消費記錄只是在list頁面用方法展示結果,沒有使用save()將其填充到
對應的欄位,就會使消費記錄因為關聯性而發生不希望的變動。
補充知識:Django models.save()的問題
Django views.py 引用models.py進行modles.objects.create()然後進行.save的問題。
我們是不能直接進行儲存的,提交到資料庫裡面的。
EX:
我們這裡通過post獲取到資訊後。
views.py def post(self,request,ab=None,all_seat=None): # 獲取使用者資訊 date = request.POST.get('date') time = request.POST.get('time')
然後
views.py seatform = SeatForm(request.POST) # 提交給資料庫 #這裡的is_valid()是Django預設的,檢查是否正確 if seatform.is_valid(): # 這裡向資料庫新增一條資訊,然後儲存 getSeat = Seat.objects.create(dateTime=date,classtime=time,status='0',user=name,number=label) getSeat.save()
上面的SeatForm()是我們在與views.py同級目錄下建立的forms.py
forms.py class SeatForm(forms.Form): #注意這裡的date和time需要與前端的命名要一直 date = forms.CharField() time = forms.CharField()
通過這樣的方法,我們就可以儲存到資料庫了。
以上這篇淺談django 模型類使用save()方法的好處與注意事項就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。