亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

django中業務邏輯和數據訪問的分離

django中業務邏輯和數據訪問的分離

呼啦一陣風 2019-11-04 14:18:50
我正在Django中編寫一個項目,并且看到80%的代碼在file中models.py。這段代碼令人困惑,并且在一段時間之后,我不再了解實際發生的事情。這是困擾我的事情:我發現模型級別(應該只負責處理數據庫中的數據)在發送電子郵件,使用API到其他服務等方面也很丑陋。另外,我發現在視圖中放置業務邏輯也是不可接受的,因為這樣很難控制。例如,在我的應用程序中,至少有三種方法來創建的新實例User,但從技術上講,它應統一創建它們。我并不總是注意到模型的方法和屬性何時變得不確定,以及何時出現副作用。這是一個簡單的例子。首先,User模型是這樣的:class User(db.Models):    def get_present_name(self):        return self.name or 'Anonymous'    def activate(self):        self.status = 'activated'        self.save()隨著時間的流逝,它變成了:class User(db.Models):    def get_present_name(self):         # property became non-deterministic in terms of database        # data is taken from another service by api        return remote_api.request_user_name(self.uid) or 'Anonymous'     def activate(self):        # method now has a side effect (send message to user)        self.status = 'activated'        self.save()        send_mail('Your account is activated!', '…', [self.email])我想要的是在代碼中分離實體:數據庫級別的數據庫實體:什么包含我的應用程序?我的應用程序的實體,業務邏輯級別:什么可以構成我的應用程序?有什么好的實踐來實現可以在Django中應用的方法?
查看完整描述

3 回答

  • 3 回答
  • 0 關注
  • 1332 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號