您的位置:首页 > 数据库

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

2017-10-10 16:03 856 查看
# -*- 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()
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: