Django数据库一对一数据关系

本文主要描述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.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)
创建完数据库模型之后,就需要创建数据库变更文件,应用数据库变更文件创建表的操作。
创建数据库变更文件: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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值