Django数据库一对一数据关系
来源:互联网 发布:美工电脑配置清单2017 编辑:程序博客网 时间:2024/06/08 06:35
本文主要描述Django数据中一对一的数据关系,创建app等配置不再赘述。
Django操作数据库,使用ORM
ORM:关系映射对象,把传统的SQL语句封装成了类和对象的形式,在操作表中的记录时,就像在操作类和对象一样。
使用默认数据库:sqlite
操作在models.py文件中完成。
一对一数据关系:
一对一关系:数据库中两个表中数据的对应关系
一个账户对应着一个联系人,而一个联系人有一个账户
一对一关系是通过在两个表之间定义相同的主键来完成。
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)创建完数据库模型之后,就需要创建数据库变更文件,应用数据库变更文件创建表的操作。创建数据库变更文件:python manage.py makemigrations应用数据库变更文件:python manage.py migrate可以使用SQLite可视化工具查看已经建立成功的数据库表由于未进行其他配置,所以只能在shell环境下,对数据库进行操作。进入shell环境的命令:python manage.py shell在shell环境下,首先要引入我们创建的数据模型。from app.models import Account,Contact往数据表中插入数据
a1 = Account(username='zs', password='222')a1.save()c1 = Contact(account=a1, address='河南', code='471300', mobile='1110')c1.save()查询:正向查询,通过账户查询该账户对应的详细信息
print a1.contact
反向查询,通过联系人详细信息查询该信息对应的账户
print c1.account
删除:
删除账户,对应的联系人信息也会被删除
a1.delete()
阅读全文
0 0
- Django数据库一对一数据关系
- django中数据库一对一,一对多,多对多关系
- Django中的数据库模型类-models.py(一对一的关系)
- Django数据库之一对一
- 数据库表设计时一对一关系
- 使用jpa注解数据库中的一对一关系
- 数据库设计实现严格的一对一关系
- Django 数据关系的处理
- 数据库中表关系(一对多,多对多,一对一)
- 数据库一对一,多对一,多对多的关系
- hibernate中数据库表中一对一关系映射
- 数据库表设计时一对一关系存在的必要性
- 数据库设计实现严格的一对一关系 (重新学习)
- Django笔记 数据库数据外键 多对多关系访问
- django 一对一查询
- Django使用MongoDB非关系型数据库
- Django-数据库多对多关系
- Django数据库一对多数据关系
- 项目常用功能模块(3)-移除数组中的指定元素
- Bluetooth蓝牙
- Android事件机制详细解读
- 笔记2
- org.gradle.api.internal.tasks.DefaultTaskInputs$TaskInput........
- Django数据库一对一数据关系
- node-mysql
- JavaSE基础入门
- 数字三角形 动态规划
- 关于保障移动电话用户资费方案选择权的通知 信部清〔2006〕630号
- Spring(1):搭建Spring3开发环境(maven+spring)
- 国内最火的 HTML、CSS、JavaScript 开源项目 Top 榜,你知多少?
- MyEclipse 2015启动tomcat服务器时, jar包无法发布到tomcat lib目录下的问题
- python中多进程编程详解