django-給外鍵關系傳值,刪除外鍵關系


反查:

  在表關系里 related_name = '反查name',自己不設置,django也會默認設置為class的小寫名字+_set  , ex: book_set.

一對一關系賦值:

class ModelStudy(View):
    ''' ClassRoom和ClassNumber是一對一關系,給外鍵傳值 '''
    def get(self, request):
        ''' 兩種方法 教室ClassRoom和教室編號ClassNumber 外鍵字段在django類里名(room_number)在數據庫名(room_number_id) '''
     # 一.1賦值對象給外鍵字段 # room_number = ClassNumber.objects.filter(class_number__exact='003')[0] # d對List切片 # c = ClassRoom() # c.room_number = room_number # c.save() # 1.2新增數據並賦值對象給新增字段 room_number = ClassNumber.objects.filter(class_number__exact='003')[0] print room_number ClassRoom.objects.create(name="python教室", room_number=room_number) # 新增數據

     # 二:獲取外鍵字段(數據庫的外鍵字段名字room_number_id)的值,將相對應的值直接賦值給該外鍵字段
     class_number = ClassNumber.object.get("id=1").room_number # 獲取教室編號具體值 ‘001’
     c = ClassRoom.object.filter(id=1)[0]
     c.room_number_id = class_number # 將‘001’復制給數據庫外鍵字段
外鍵字段在django類里名(room_number)在數據庫名(room_number_id)
     c.save()
return HttpResponse("ojbk")

 多對一:

類似一對一,只是 ''多''的一方可以對應多個"一"方。 ps: "一"放通過反查,會有不止一條數據。可以通過+all()獲取。

假設兩張表:Book書 + Reply評論 表。為多對一,Reply為"多''.  那么"一",Book反查是,Book.object.get(id=1).reply_set.all()          # reply_set是不設置related_name時,django自己設置的

多對多:

class ModelStudy(View):
    ''' Students和Teachers是多對多關系 '''
    def get(self, request):
        ''' 兩種情況 '''
        # 主類(外鍵所在類)數據已經存在
        # t = Teachers.objects.get(id=1)
        # s = Students.objects.get(name="學生3")
        # s.teacher.add(t) # 多對多需要add數據
        # s.save()

        # 主類數據不存在,新增數據時, 需先save()
        t = Teachers.objects.get(id=1)
        s = Students(name='xiaodong1', age=10, gender="")
        s.save() # 先存新增數據
        s.teacher.add(t) # 再給新增數據添加多對多關系   可以add(t, t1, t2)多個對應的關系
        s.save()
        return HttpResponse("ojbk")

 刪除關系數據

先查出對應的關系數據,在刪除

class ModelStudy(View):
    ''' Students和Teachers是多對多關系 '''
    def get(self, request):
        ''' 兩種情況 '''
        s = Students.objects.get(id=1)
        t = s.teacher.all() # 多對多 s.teacher是一個<QuerySet>list對象 通過反查取值需要all(),get(),filter之類的
        for x in t: # 刪除所有對應關系 haha...
            s.teacher.remove(x)
        return HttpResponse("ojbk")

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM