django在開(kāi)發(fā)中取消外鍵約束的實(shí)現(xiàn)
我就廢話不多說(shuō)了,大家還是直接看代碼吧!
# 在setting設(shè)置外鍵’OPTIONS’: { 'init_command': 'SET foreign_key_checks = 0;', }
補(bǔ)充知識(shí):django-給外鍵關(guān)系傳值,刪除外鍵關(guān)系
反查:
在表關(guān)系里 related_name = ’反查name’,自己不設(shè)置,django也會(huì)默認(rèn)設(shè)置為class的小寫(xiě)名字+_set , ex: book_set.
一對(duì)一關(guān)系賦值:
class ModelStudy(View): ’’’ ClassRoom和ClassNumber是一對(duì)一關(guān)系,給外鍵傳值 ’’’ def get(self, request): ’’’ 兩種方法 教室ClassRoom和教室編號(hào)ClassNumber 外鍵字段在django類(lèi)里名(room_number)在數(shù)據(jù)庫(kù)名(room_number_id) ’’’ # 一.1賦值對(duì)象給外鍵字段 # room_number = ClassNumber.objects.filter(class_number__exact=’003’)[0] # d對(duì)List切片 # c = ClassRoom() # c.room_number = room_number # c.save() # 1.2新增數(shù)據(jù)并賦值對(duì)象給新增字段 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ù)庫(kù)的外鍵字段名字room_number_id)的值,將相對(duì)應(yīng)的值直接賦值給該外鍵字段 class_number = ClassNumber.object.get('id=1').room_number # 獲取教室編號(hào)具體值 ‘001’ c = ClassRoom.object.filter(id=1)[0] c.room_number_id = class_number # 將‘001’復(fù)制給數(shù)據(jù)庫(kù)外鍵字段 外鍵字段在django類(lèi)里名(room_number)在數(shù)據(jù)庫(kù)名(room_number_id) c.save()return HttpResponse('ojbk')
多對(duì)一:
類(lèi)似一對(duì)一,只是 ’’多’’的一方可以對(duì)應(yīng)多個(gè)'一'方。 ps: '一'放通過(guò)反查,會(huì)有不止一條數(shù)據(jù)。可以通過(guò)+all()獲取。
假設(shè)兩張表:Book書(shū) + Reply評(píng)論 表。為多對(duì)一,Reply為'多’’. 那么'一',Book反查是,Book.object.get(id=1).reply_set.all() # reply_set是不設(shè)置related_name時(shí),django自己設(shè)置的
多對(duì)多:
class ModelStudy(View): ’’’ Students和Teachers是多對(duì)多關(guān)系 ’’’ def get(self, request): ’’’ 兩種情況 ’’’ # 主類(lèi)(外鍵所在類(lèi))數(shù)據(jù)已經(jīng)存在 # t = Teachers.objects.get(id=1) # s = Students.objects.get(name='學(xué)生3') # s.teacher.add(t) # 多對(duì)多需要add數(shù)據(jù) # s.save() # 主類(lèi)數(shù)據(jù)不存在,新增數(shù)據(jù)時(shí), 需先save() t = Teachers.objects.get(id=1) s = Students(name=’xiaodong1’, age=10, gender='男') s.save() # 先存新增數(shù)據(jù) s.teacher.add(t) # 再給新增數(shù)據(jù)添加多對(duì)多關(guān)系 可以add(t, t1, t2)多個(gè)對(duì)應(yīng)的關(guān)系 s.save() return HttpResponse('ojbk')
刪除關(guān)系數(shù)據(jù)
先查出對(duì)應(yīng)的關(guān)系數(shù)據(jù),在刪除
class ModelStudy(View): ’’’ Students和Teachers是多對(duì)多關(guān)系 ’’’ def get(self, request): ’’’ 兩種情況 ’’’ s = Students.objects.get(id=1) t = s.teacher.all() # 多對(duì)多 s.teacher是一個(gè)<QuerySet>list對(duì)象 通過(guò)反查取值需要all(),get(),filter之類(lèi)的 for x in t: # 刪除所有對(duì)應(yīng)關(guān)系 haha... s.teacher.remove(x) return HttpResponse('ojbk')
以上這篇django實(shí)現(xiàn)在開(kāi)發(fā)中取消外鍵約束就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. python numpy庫(kù)np.percentile用法說(shuō)明2. CSS自定義滾動(dòng)條樣式案例詳解3. 關(guān)于Mysql-connector-java驅(qū)動(dòng)版本問(wèn)題總結(jié)4. Java Spring WEB應(yīng)用實(shí)例化如何實(shí)現(xiàn)5. 通過(guò)工廠模式返回Spring Bean方法解析6. python 批量下載bilibili視頻的gui程序7. Intellij IDEA連接Navicat數(shù)據(jù)庫(kù)的方法8. PHP 面向?qū)ο蟪绦蛟O(shè)計(jì)之類(lèi)屬性與類(lèi)常量實(shí)現(xiàn)方法分析9. 使用css實(shí)現(xiàn)全兼容tooltip提示框10. JSP實(shí)現(xiàn)客戶信息管理系統(tǒng)
