Tādi lasītāji kā jūs palīdz atbalstīt MUO. Veicot pirkumu, izmantojot saites mūsu vietnē, mēs varam nopelnīt filiāles komisiju.
Datu bāzes attiecības apraksta savienojumu starp dažādām datu bāzes tabulām. Attiecības nosaka, kā uzglabāt un izgūt datus. Django labi darbojas ar relāciju datu bāzu sistēmām (RDBMS). Tāpēc tas atbalsta datu bāzes tabulu attiecības.
Attiecību veidi ir atkarīgi no jūsu lietojumprogrammas prasībām un tajā modelētajiem datiem. Labas attiecības starp Django modeļiem un datubāzi uzlabo datu uzturēšanu. Tas ietver vaicājumu veiktspējas uzlabošanu un datu dublēšanās samazināšanu.
Varat uzzināt, kā Django datu bāzes attiecības ietekmē lietojumprogrammu veiktspēju, izpētot trīs galvenos attiecību veidus.
Datu bāzu attiecības
Relāciju datu bāzu sistēmas atbalsta trīs datu bāzes attiecību veidus. Šīs attiecības ir viens pret daudziem, daudzi pret daudziem un viens pret vienu. Datu bāzes relācijas veids ietekmē jūsu lietojumprogrammas lietošanas gadījumus.
Django modeļi apzīmē datu bāzes tabulas lietotnē. Lai izveidotu labu datu bāzes sistēmu, starp tabulām ir jāizveido labas attiecības. Datu bāzes relācijas nosaka, kā saglabāt un parādīt datus jūsu lietojumprogrammā.
Lai izprastu datu bāzes attiecības, sāciet ar izveidojot Django projektu nosaukts Kapuces. Lietotne būs apkārtnes sociālais tīkls. Tas pārvaldīs dažādu mikrorajonu sociālās aktivitātes, drošību un uzņēmumus.
Iedzīvotāji var reģistrēties, pierakstīties un izveidot profilus. Viņi var arī izveidot ziņas un biznesa sludinājumus, lai ikviens to varētu redzēt.
Lai sāktu, izveidojiet datu bāzi, kurā tiks saglabāti visi apkārtnes dati. Pēc tam jūs izveidosit modeļus Profils, NeighborHood, Business un Post. Lai izveidotu modeļus, ir jānosaka datu bāzes tabulām nepieciešamās attiecības.
Viena pret vienu datu bāzes attiecības
Attiecības viens pret vienu nozīmē, ka ieraksts vienā Django modelī ir saistīts ar citu ierakstu citā modelī. Abi ieraksti ir atkarīgi viens no otra. Šajā gadījumā, Profila modelis atkarīgs no Lietotāja modelis lai izveidotu rezidentu profilus.
Tāpēc katram lietotnē reģistrētajam iedzīvotājam var būt tikai viens profils. Turklāt bez lietotāja profils nevar pastāvēt.
no django.db imports modeļiem
nodjango.contrib.auth.modeļiimportsLietotājsklasēProfils(modeļi. Modelis):
lietotājs = modeļi. OneToOneField (lietotājs, on_delete=modeļi. KASKĀDE, saistītais_nosaukums='profils')
nosaukums = modeļi. CharField (max_length=80, tukšs =Taisnība)
bio = modeļi. Teksta lauks (max_length=254, tukšs =Taisnība)
profile_picture = CloudinaryField('profila bilde', noklusējuma ='default.png')
atrašanās vieta = modeļi. CharField (max_length=50, tukšs =Taisnība, null=Taisnība)
e-pasts = modeļi. EmailField(null=Taisnība)
def__str__(pats):
atgriezties f'{sevi.user.username} profils'
Django lietotāja modelis ir Django iebūvēts autentifikācijas modelis. Jums tam nav jāizveido modelis. Tā vietā importējiet to no django.contrib.auth. The OneToOneField() uz Profila modelis definē attiecības viens pret vienu.
The on_delete=modeļi. KASKĀDE arguments neļauj dzēst kādu no šiem ierakstiem. Jums ir jāizdzēš ieraksti no abām tabulām.
Varat izmantot Django administratora saskarni, lai vizualizētu attiecības savā lietotnē. Lai pieteiktos Django admin, jums jāreģistrējas kā administratora lietotājam, kas pazīstams kā a superlietotājs.
Izveidojiet superlietotāju, terminālī izpildot šādu komandu:
pitonspārvaldīt.pyizveidot superlietotāju
Tiks parādīts aicinājums ievadīt lietotājvārdu, e-pastu un paroli. Kad tas ir izdarīts, palaidiet serveri.
Pārlūkprogrammā atveriet administratora lapu, izmantojot URL http://127.0.0.1:8000/admin.
Jūs redzēsit administratora lapu, kurā varēsit pieteikties ar iepriekš izveidotajiem akreditācijas datiem. Kad esat pieteicies, jūs redzēsit Grupas un Lietotāji objektus. Django autentifikācijas sistēma pārvalda šos divus modeļus. Apakšā jūs redzēsit Profila modelis.
Atveriet Profils modeli un turpiniet pievienot profilu. Jūs redzēsiet, kā tas izskatās šādi:
Ņemiet vērā, ka jums ir iespēja izveidot lietotāja profilu. Datu tips OneToOneField() ļauj izveidot profilus autentificētiem lietotājiem. Šādi lietotne pārvalda savstarpējās attiecības.
Attiecības viens pret daudziem
Attiecības viens pret daudziem nozīmē, ka viens ieraksts modelī ir saistīts ar daudziem ierakstiem citā modelī. Tās tiek sauktas arī par daudzpusējām attiecībām.
Jūsu gadījumā viens administrators var izveidot vairākas apkaimes. Bet katra apkaime var piederēt tikai vienam administratoram. Lai definētu šādas attiecības, varat izmantot datu tipu ForeignKey.
Django ir iebūvēts administratora interfeiss. Jums tam nav jāizveido modelis. Administratoram ir tiesības pārvaldīt saturu un vizualizēt lietotni no administratora paneļa.
Modelim, kurā ir daudz ierakstu, būs Sveša atslēga. Tas definē attiecības kā viens pret daudziem. Tālāk redzamais kods parāda, kur novietot atslēgu.
klasēapkārtne(modeļi. Modelis):
admin = modeļi. Sveša atslēga("Profils", on_delete=modeļi. KASKĀDE, saistītais_nosaukums='kapuci')
nosaukums = modeļi. CharField (max_length=50)
atrašanās vieta = modeļi. CharField (max_length=60)
hood_logo = CloudinaryField('hood_logo', noklusējuma ='default.png')
apraksts = modeļi. Teksta lauks()
health_tell = modeļi. IntegerField(null=Taisnība, tukšs =Taisnība)
policijas_numurs = modeļi. IntegerField(null=Taisnība, tukšs =Taisnība)
Skaits = modeļi. IntegerField(null=Taisnība, tukšs =Taisnība)
def__str__(pats):
atgriezties f'{sevi.name} pārsegs'
Jūs varat redzēt attiecības lietotnē, kā parādīts attēlā:
The Kaimiņvalsts modelim tagad ir administrators. Lai ikviens varētu izveidot apkaimi, viņam ir jābūt administratora tiesībām. Un vienā apkaimē nevar būt daudz administratoru.
Daudzu pret daudziem datu bāzu attiecības
Attiecībās no daudziem pret daudziem daudzi ieraksti vienā modelī ir saistīti ar citiem citā modelī. Piemēram, Post un Bizness modeļiem var būt vairāki viens otra ieraksti. Lietotāji savos ierakstos var ievietot vairākas biznesa reklāmas un otrādi.
Tomēr daudzu pret daudziem attiecību izveide var radīt neprecīzus datus. Citos ietvaros jums būtu jāizveido jauna tabula, lai savienotu abas tabulas.
Django tam ir risinājums. Ja izmantojat lauku daudzi pret daudziem, tiek izveidota jauna tabula, kas kartē abas tabulas kopā. Lauku “daudzi pret daudziem” varat ievietot jebkurā no diviem modeļiem, taču tam nevajadzētu būt abos modeļos.
klasēPost(modeļi. Modelis):
nosaukums = modeļi. CharField (max_length=120, null=Taisnība)
pasts = modeļi. Teksta lauks()
datums = modeļi. DateTimeField (auto_now_add=Taisnība)
lietotājs = modeļi. ForeignKey (profils, on_delete=models. KASKĀDE, saistītais_nosaukums='post_owner')
kapuci = modeļi. ForeignKey (NeighbourHood, on_delete=models. KASKĀDE, saistītais_nosaukums='hood_post')
bizness = modeļi. ManyToManyField (uzņēmējdarbība)
def__str__(pats):
atgriezties f'{sevi.title} ziņa"
Tagad, kad skatāties Post modeli administrēšanas panelī, vienai ziņai varat pievienot vairākus uzņēmumus.
Django vienkāršo datu bāzu attiecības
Datu bāzes veids, kuru izmantojat savai lietojumprogrammai, nosaka, kā izmantot datus. Django ir visaptveroša sistēma, kas atvieglo relāciju datu bāzu savienošanu un darbību.
Django funkcijas atvieglo datu glabāšanu un izgūšanu no saistītajām tabulām. Tam ir iebūvētas API, kas savieno un izveido datu bāzes attiecības jūsu lietotnei.
Datu bāzes attiecības nosaka jūsu lietojumprogrammas darbību. Tas, vai izmantojat attiecības viens pret vienu, viens pret daudziem vai daudzi pret daudziem, ir atkarīgs no jums.
Izmantojot Django, varat konfigurēt un pārbaudīt funkcijas, nepārkāpjot lietojumprogrammu. Izmantojiet Django, lai aizsargātu datu bāzes sistēmas un optimizētu savu izstrādātāja pieredzi.