国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

django在開發(fā)中取消外鍵約束的實現(xiàn)

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

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

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

補充知識:django-給外鍵關(guān)系傳值,刪除外鍵關(guān)系

反查:

在表關(guān)系里 related_name = ’反查name’,自己不設(shè)置,django也會默認(rèn)設(shè)置為class的小寫名字+_set , ex: book_set.

一對一關(guān)系賦值:

class ModelStudy(View): ’’’ ClassRoom和ClassNumber是一對一關(guān)系,給外鍵傳值 ’’’ def get(self, request): ’’’ 兩種方法 教室ClassRoom和教室編號ClassNumber 外鍵字段在django類里名(room_number)在數(shù)據(jù)庫名(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新增數(shù)據(jù)并賦值對象給新增字段 room_number = ClassNumber.objects.filter(class_number__exact=’003’)[0] print room_number ClassRoom.objects.create(name='python教室', room_number=room_number) # 新增數(shù)據(jù) # 二:獲取外鍵字段(數(shù)據(jù)庫的外鍵字段名字room_number_id)的值,將相對應(yīng)的值直接賦值給該外鍵字段 class_number = ClassNumber.object.get('id=1').room_number # 獲取教室編號具體值 ‘001’ c = ClassRoom.object.filter(id=1)[0] c.room_number_id = class_number # 將‘001’復(fù)制給數(shù)據(jù)庫外鍵字段 外鍵字段在django類里名(room_number)在數(shù)據(jù)庫名(room_number_id) c.save()return HttpResponse('ojbk')

多對一:

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

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

多對多:

class ModelStudy(View): ’’’ Students和Teachers是多對多關(guān)系 ’’’ def get(self, request): ’’’ 兩種情況 ’’’ # 主類(外鍵所在類)數(shù)據(jù)已經(jīng)存在 # t = Teachers.objects.get(id=1) # s = Students.objects.get(name='學(xué)生3') # s.teacher.add(t) # 多對多需要add數(shù)據(jù) # s.save() # 主類數(shù)據(jù)不存在,新增數(shù)據(jù)時, 需先save() t = Teachers.objects.get(id=1) s = Students(name=’xiaodong1’, age=10, gender='男') s.save() # 先存新增數(shù)據(jù) s.teacher.add(t) # 再給新增數(shù)據(jù)添加多對多關(guān)系 可以add(t, t1, t2)多個對應(yīng)的關(guān)系 s.save() return HttpResponse('ojbk')

刪除關(guān)系數(shù)據(jù)

先查出對應(yīng)的關(guān)系數(shù)據(jù),在刪除

class ModelStudy(View): ’’’ Students和Teachers是多對多關(guān)系 ’’’ 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: # 刪除所有對應(yīng)關(guān)系 haha... s.teacher.remove(x) return HttpResponse('ojbk')

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

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 99精品这里只有精品高清视频 | 一区二区三区免费视频观看 | 男人的天堂网在线 | 免费中国一级啪啪片 | 成人免费在线观看视频 | 欧美成人精品动漫在线专区 | 国产欧美视频综合二区 | 黄页网址免费观看18网站 | 欧美国产永久免费看片 | 一区二区三区四区五区六区 | 在线观看亚洲免费视频 | 亚洲精品国产男人的天堂 | 91香蕉成人免费网站 | 精品国产欧美一区二区 | 亚洲第一区视频在线观看 | 婷婷在线成人免费观看搜索 | 在线日韩三级 | 国产成人精品免费视频网页大全 | 看全色黄大色黄大片女图片 | a级毛片免费观看在线播放 a级毛片免费看 | 欧美一级爱操视频 | 精品成人 | 波多野结衣一区二区 三区 波多野结衣一区二区三区88 | 欧美三级不卡视频 | 影院成人区精品一区二区婷婷丽春院影视 | 亚洲男女在线 | 欧美亚洲日本在线 | 国产精品免费看久久久香蕉 | 欧美一级级毛片 | 日韩精品免费一区二区 | 成人免费看www网址入口 | 一级aaaaaa毛片免费同男同女 | 1a级毛片免费观看 | 成年男女拍拍拍免费视频 | 亚洲精品手机在线 | 日产一区两区三区 | 在线观看国产日本 | 亚洲性生活视频 | 99福利资源久久福利资源 | 亚洲精品久久久午夜伊人 | 久久的精品99精品66 |