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


Posted in Python onMay 30, 2018

如下所示:

# -*- 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(一对一的关系)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
详解Python中for循环的使用
Apr 14 Python
在Python的web框架中配置app的教程
Apr 30 Python
Python实现聊天机器人的示例代码
Jul 09 Python
在python中安装basemap的教程
Sep 20 Python
python构建基础的爬虫教学
Dec 23 Python
python实现合并两个排序的链表
Mar 03 Python
详解Python 调用C# dll库最简方法
Jun 20 Python
Django外键(ForeignKey)操作以及related_name的作用详解
Jul 29 Python
python实现递归查找某个路径下所有文件中的中文字符
Aug 31 Python
Python实现图片识别加翻译功能
Dec 26 Python
Python调用高德API实现批量地址转经纬度并写入表格的功能
Jan 12 Python
python常量折叠基础知识点讲解
Feb 28 Python
Python实现的读取电脑硬件信息功能示例
May 30 #Python
Python应用库大全总结
May 30 #Python
Django中反向生成models.py的实例讲解
May 30 #Python
Python RabbitMQ消息队列实现rpc
May 30 #Python
python日期时间转为字符串或者格式化输出的实例
May 29 #Python
python 集合 并集、交集 Series list set 转换的实例
May 29 #Python
使用Django启动命令行及执行脚本的方法
May 29 #Python
You might like
php is_file 判断给定文件名是否为一个正常的文件
2010/05/10 PHP
php使用函数pathinfo()、parse_url()和basename()解析URL
2016/11/25 PHP
简单谈谈PHP面向对象之标识对象
2017/06/27 PHP
php语言注释,单行注释和多行注释
2018/01/21 PHP
Javascript-Mozilla和IE中的一个函数直接量的问题分析
2007/08/12 Javascript
js form 验证函数 当前比较流行的错误提示
2009/06/23 Javascript
基于jquery的分页控件(C#)
2011/01/06 Javascript
映彩衣的js随笔(js图片切换效果)
2011/07/31 Javascript
Javascript中产生固定结果的函数优化技巧
2013/01/16 Javascript
JavaScript全排列的六种算法 具体实现
2013/06/29 Javascript
jquery选择器、属性设置用法经验总结
2013/09/08 Javascript
深入理解javascript变量声明
2014/11/20 Javascript
AngularJS 使用$sce控制代码安全检查
2016/01/05 Javascript
Jquery实现简单的轮播效果(代码管用)
2016/03/14 Javascript
基于JavaScript Array数组方法(新手必看篇)
2016/08/20 Javascript
JavaScript函数参数的传递方式详解
2017/03/06 Javascript
详解微信小程序实现WebSocket心跳重连
2018/07/31 Javascript
Vue利用Blob下载原生二进制数组文件
2019/09/25 Javascript
原生js canvas实现鼠标跟随效果
2020/08/02 Javascript
python实现的简单抽奖系统实例
2015/05/22 Python
Python实现简单的文件传输与MySQL备份的脚本分享
2016/01/03 Python
pandas 对series和dataframe进行排序的实例
2018/06/09 Python
详解Python 数据库的Connection、Cursor两大对象
2018/06/25 Python
python批量修改ssh密码的实现
2019/08/08 Python
详解matplotlib中pyplot和面向对象两种绘图模式之间的关系
2021/01/22 Python
css3中单位px,em,rem,vh,vw,vmin,vmax的区别及浏览器支持情况
2016/12/06 HTML / CSS
工作自荐信
2013/12/11 职场文书
装修设计师求职信
2014/02/26 职场文书
2014年第四季度入党积极分子思想汇报(十八届四中全会)
2014/11/03 职场文书
英文感谢信格式
2015/01/21 职场文书
高中教师个人总结
2015/02/10 职场文书
鉴史问廉观后感
2015/06/10 职场文书
女方家长婚礼致辞
2015/07/27 职场文书
汉语拼音教学反思
2016/02/22 职场文书
关于感恩老师的古诗句
2019/08/20 职场文书
如何Python使用re模块实现okenizer
2022/04/30 Python