django在開(kāi)發(fā)中取消外鍵約束的實(shí)現(xiàn)
我就廢話(huà)不多說(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è)參考,也希望大家多多支持腳本之家。
相關(guān)文章
簡(jiǎn)述 Python 的類(lèi)和對(duì)象
這篇文章主要介紹了Python 的類(lèi)和對(duì)象的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下2020-08-08
Python進(jìn)階之如何快速將變量插入有序數(shù)組
在我們學(xué)習(xí)python的過(guò)程中,學(xué)習(xí)序列是一門(mén)必修課。本文我們就來(lái)一起看一看Python是如何快速將變量插入有序數(shù)組的,感興趣的可以了解一下2023-04-04
python Opencv計(jì)算圖像相似度過(guò)程解析
這篇文章主要介紹了python Opencv計(jì)算圖像相似度過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12
python實(shí)現(xiàn)用戶(hù)管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)用戶(hù)管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
基于Python中numpy數(shù)組的合并實(shí)例講解
下面小編就為大家分享一篇基于Python中numpy數(shù)組的合并實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-04-04

