午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

django在開發中取消外鍵約束的實現

瀏覽:110日期:2024-10-03 08:21:27

我就廢話不多說了,大家還是直接看代碼吧!

# 在setting設置外鍵’OPTIONS’: { 'init_command': 'SET foreign_key_checks = 0;', }

補充知識: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')

以上這篇django實現在開發中取消外鍵約束就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 蜜桃在线一区二区 | 欧美一二区视频 | 亚洲免费高清 | 日韩专区在线 | 免费色网站 | 色资源网| 亚洲三级国产 | 国产精品人人 | 超碰婷婷| 日本久久高清 | 在线看黄色av | 精品免费国产 | 五月天婷婷丁香网 | 日韩欧美三级视频 | 日韩第三页| 久久久久久久久国产精品 | 日韩一区二区在线播放 | 国产欧美一区二区三区在线观看视频 | 黄色一级片欧美 | 在线观看中文字幕视频 | 超碰1997 | 男人的天堂黄色 | 欧美亚洲国产一区二区三区 | 成人手机在线播放 | 国产成人av网站 | 欧美亚洲日本国产 | 美女久久久久 | 97超碰免费观看 | 日韩欧美中文字幕一区二区 | 亚欧精品视频一区二区三区 | 国产婷婷色 | 91成人亚洲| 51.cc网站入口永久入口 | 伊人久久久久久久久久 | 四虎成人网 | 精品欧美一区二区三区久久久 | 免费黄网站在线观看 | 精品视频久久久 | 五月婷婷中文 | 国产美女网站 | 玖草视频在线观看 |