浅谈Django中的数据库模型类-models.py(一对一的关系)

Lassie ·
更新时间:2024-11-14
· 760 次阅读

如下所示:

# -*- coding: utf-8 -*- from __future__ import unicode_literals from django.db import models # Create your models here. # 一对一关系:数据库中两个表中数据的对应关系 # 一个账户对应着一个联系人,而一个联系人有一个账户 # 一对一关系是通过在两个表之间定义相同的主键来完成 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'注册时间') class Meta: db_table = 'Account' # 该函数是负责展示该类对象的详细信息的函数,根据需要自定义展示的内容 def __unicode__(self): return 'Account:%s'%self.username class Contact(models.Model): # 在Contact中,关联Account表,让两个表的数据产生联系 # 第一个参数:是被关联的模型名称 # 第二个参数:当Account中的一条数据被删除的时候,与之对应的Contact数据也会被删除 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:通过联系人对象反向查询该信息所属的人 return 'Contact:%s-%s-%s'%(self.account.username,self.address,self.mobile) # ORM:关系映射对象,把传统的SQL语句封装成了类和对象的形式,在操作表中的数据记录时,就像在操作类和对象 # 一对一的正向查询和反向查询 a1 = Account(username='dawei',password='333') a1.save() c1 = Contact(account=a1,address='xinmi',code='450000',mobile='13212344321') c1.save() print a1.contact# 正向查询,通过账户查询该账户对应的详细信息 print c1.account# 反向查询,通过详细信息查询信息对应的账户 # a1.contact.mobile # a1.contact.address # a1.contact.code # c1.account.username # c1.account.password # 删除账户,对应的联系人信息也会被删除 # a1.delete()

以上这篇浅谈Django中的数据库模型类-models.py(一对一的关系)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持软件开发网。

您可能感兴趣的文章:django模型中的字段和model名显示为中文小技巧分享Django中模型Model添加JSON类型字段的方法django模型层(model)进行建表、查询与删除的基础教程Django 根据数据模型models创建数据表的实例Django 模型类(models.py)的定义详解Django的models模型的具体使用在Django的模型和公用函数中使用惰性翻译对象利用信号如何监控Django模型对象字段值的变化详解django框架面向对象ORM模型继承用法实例分析Django框架model模型对象验证实现方法分析



数据库模型 数据 关系 模型 models Django 数据库

需要 登录 后方可回复, 如果你还没有账号请 注册新账号