淺談Django中的數(shù)據(jù)庫(kù)模型類-models.py(一對(duì)一的關(guān)系)
更新時(shí)間:2018年05月30日 09:10:35 作者:weixin_34322964
今天小編就為大家分享一篇淺談Django中的數(shù)據(jù)庫(kù)模型類-models.py(一對(duì)一的關(guān)系),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
如下所示:
# -*- coding: utf-8 -*- from __future__ import unicode_literals from django.db import models # Create your models here. # 一對(duì)一關(guān)系:數(shù)據(jù)庫(kù)中兩個(gè)表中數(shù)據(jù)的對(duì)應(yīng)關(guān)系 # 一個(gè)賬戶對(duì)應(yīng)著一個(gè)聯(lián)系人,而一個(gè)聯(lián)系人有一個(gè)賬戶 # 一對(duì)一關(guān)系是通過在兩個(gè)表之間定義相同的主鍵來完成 class Account(models.Model): username = models.CharField(max_length=20, null=True, blank=True, verbose_name=u'用戶名') password = models.CharField(max_length=40, null=True, blank=True, verbose_name=u'密碼') register_date = models.DateField(auto_now_add=True, null=True, blank=True, verbose_name=u'注冊(cè)時(shí)間') class Meta: db_table = 'Account' # 該函數(shù)是負(fù)責(zé)展示該類對(duì)象的詳細(xì)信息的函數(shù),根據(jù)需要自定義展示的內(nèi)容 def __unicode__(self): return 'Account:%s'%self.username class Contact(models.Model): # 在Contact中,關(guān)聯(lián)Account表,讓兩個(gè)表的數(shù)據(jù)產(chǎn)生聯(lián)系 # 第一個(gè)參數(shù):是被關(guān)聯(lián)的模型名稱 # 第二個(gè)參數(shù):當(dāng)Account中的一條數(shù)據(jù)被刪除的時(shí)候,與之對(duì)應(yīng)的Contact數(shù)據(jù)也會(huì)被刪除 account = models.OneToOneField(Account, on_delete=models.CASCADE, primary_key=True) address = models.CharField(max_length=100, null=True) code = models.CharField(max_length=20, null=True) mobile = models.CharField(max_length=20, null=True) class Meta: db_table = 'Contact' def __unicode__(self): # self.account:通過聯(lián)系人對(duì)象反向查詢?cè)撔畔⑺鶎俚娜? return 'Contact:%s-%s-%s'%(self.account.username,self.address,self.mobile) # ORM:關(guān)系映射對(duì)象,把傳統(tǒng)的SQL語句封裝成了類和對(duì)象的形式,在操作表中的數(shù)據(jù)記錄時(shí),就像在操作類和對(duì)象 # 一對(duì)一的正向查詢和反向查詢 a1 = Account(username='dawei',password='333') a1.save() c1 = Contact(account=a1,address='xinmi',code='450000',mobile='13212344321') c1.save() print a1.contact# 正向查詢,通過賬戶查詢?cè)撡~戶對(duì)應(yīng)的詳細(xì)信息 print c1.account# 反向查詢,通過詳細(xì)信息查詢信息對(duì)應(yīng)的賬戶 # a1.contact.mobile # a1.contact.address # a1.contact.code # c1.account.username # c1.account.password # 刪除賬戶,對(duì)應(yīng)的聯(lián)系人信息也會(huì)被刪除 # a1.delete()
以上這篇淺談Django中的數(shù)據(jù)庫(kù)模型類-models.py(一對(duì)一的關(guān)系)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- django模型中的字段和model名顯示為中文小技巧分享
- Django中模型Model添加JSON類型字段的方法
- django模型層(model)進(jìn)行建表、查詢與刪除的基礎(chǔ)教程
- Django 根據(jù)數(shù)據(jù)模型models創(chuàng)建數(shù)據(jù)表的實(shí)例
- Django 模型類(models.py)的定義詳解
- Django的models模型的具體使用
- 在Django的模型和公用函數(shù)中使用惰性翻譯對(duì)象
- 利用信號(hào)如何監(jiān)控Django模型對(duì)象字段值的變化詳解
- django框架面向?qū)ο驩RM模型繼承用法實(shí)例分析
- Django框架model模型對(duì)象驗(yàn)證實(shí)現(xiàn)方法分析
相關(guān)文章
Python深度學(xué)習(xí)理解pytorch神經(jīng)網(wǎng)絡(luò)批量歸一化
這篇文章主要是Python深度學(xué)習(xí)篇,通過示例的詳解讓大家更好的理解pytorch神經(jīng)網(wǎng)絡(luò)批量歸一化,有需要的的朋友可以借鑒參考下,希望能夠有所幫助2021-10-10
python處理json文件的四個(gè)常用函數(shù)
這篇文章主要介紹了python處理json文件的四個(gè)常用函數(shù),主要包括json.load()和json.dump()及json.loads()還有json.dumps(),需要的朋友可以參考一下2022-07-07
python神經(jīng)網(wǎng)絡(luò)MobileNetV3?large模型的復(fù)現(xiàn)詳解
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)MobileNetV3?large模型的復(fù)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
python實(shí)現(xiàn)年會(huì)抽獎(jiǎng)程序
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)年會(huì)抽獎(jiǎng)程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01
Python3 使用pip安裝git并獲取Yahoo金融數(shù)據(jù)的操作
這篇文章主要介紹了Python3 使用pip安裝git并獲取Yahoo金融數(shù)據(jù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-04-04

