Django中的数据库模型类-models.py(一对一的关系)
来源:互联网 发布:电子商务软件教材 编辑:程序博客网 时间:2024/05/18 03:40
# -*- coding: utf-8 -*-from __future__ import unicode_literalsfrom 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.usernameclass 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()
阅读全文
0 0
- Django中的数据库模型类-models.py(一对一的关系)
- Django中的数据库模型类-models.py(一对多的关系)
- Django中的数据库模型类-models.py(多对多的关系)
- models.py---Django中的数据库模型
- Django中models.py(添加管理类模型)
- Django中的模型与数据库(Models and database)
- Django数据库一对一数据关系
- Django(二) models.py
- 初识Django-models.py
- Django Model.py数据库模型
- django修改models.py后同步更新到数据库
- 利用sqlacodegen生成models.py数据库模型文件
- Django的models.py在外部独立使用
- django models 模型
- django 模型 models详解
- 使用Django的models创建mysql数据库
- django操作mysql数据库&models的使用
- Django根据现有数据库,自动生成models模型文件
- [深度学习PART I] 单层感知器
- encode string with shortest length(路还很远)
- 逻辑回归--sklearn基本使用
- 作为程序员,我们应不应学好英语?
- Linux 新增开机启动服务
- Django中的数据库模型类-models.py(一对一的关系)
- keras实现VGG16 CIFAR10数据集
- 在map上标记point
- Elasticsearch的PHP的API使用(一)
- 使用js在网页中实现一个计算当年还剩多少时间的倒数计时程序
- 编程能力七段论(腾讯推送)
- wireshark基本用法及过虑规则
- 公式宝典之颜色混合模式公式
- 文章标题