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

作者:weixin_34322964 时间:2024-01-24 18:32:11 

如下所示:


# -*- 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()

来源:https://blog.csdn.net/weixin_34322964/article/details/78193722

标签:django,models.py,模型类
0
投稿

猜你喜欢

  • python数字类型math库原理解析

    2021-11-27 16:34:50
  • asp文章干扰码实现方法

    2007-08-19 18:07:00
  • cv2.imread 和 cv2.imdecode 用法及区别

    2023-12-03 06:15:49
  • jsp/javascript打印九九乘法表代码

    2024-03-23 02:23:17
  • JsonServer安装及启动过程图解

    2023-08-12 20:06:02
  • MYSQL每隔10分钟进行分组统计的实现方法

    2024-01-22 13:56:42
  • 使用pandas的DataFrame的plot方法绘制图像的实例

    2023-07-02 08:33:52
  • instanceof 内部机制探析

    2009-09-25 13:09:00
  • 简单方法实现网页自动适应任何分辨率任何窗口大小

    2008-09-13 19:28:00
  • Python 使用 prettytable 库打印表格美化输出功能

    2021-10-25 08:42:54
  • python实现雪花飘落效果实例讲解

    2022-08-29 07:31:55
  • SQL语句练习实例之七 剔除不需要的记录行

    2024-01-17 21:15:04
  • MYSQL教程:表达式操作符和数据类型转换

    2009-02-27 15:51:00
  • 解决python xlrd无法读取excel文件的问题

    2022-01-25 10:48:44
  • Go语言LeetCode题解1046最后一块石头的重量

    2024-05-29 22:08:19
  • Python 获取当前所在目录的方法详解

    2021-07-19 09:41:14
  • 详解Django中六个常用的自定义装饰器

    2021-02-10 03:03:09
  • 画pytorch模型图,以及参数计算的方法

    2023-09-25 09:12:58
  • Go简单实现协程池的实现示例

    2024-02-19 07:35:16
  • Python使用tkinter制作在线翻译软件

    2021-04-19 10:36:06
  • asp之家 网络编程 m.aspxhome.com