Django 模型层 orm 多表操作

作者: 别动我名字呀 | 来源:发表于2019-05-23 00:29 被阅读1次

表关系总结:

跟SQL的 关系 一样。注意在一对多中,应该把外键定义在多的当中。

  • 一对一:models.OneToOneField(to='表名', to_field='字段名', on_delete=models.CASCADE)
    定义在哪个类中都可以
    例如:员工基本信息类-员工详细信息类. 员工工号
  • 一对多:models.ForeignKey(to='表名', to_field='字段名', on_delete=models.CASCADE) 定义在多的类中。
    例如:新闻类-新闻类型类 体育新闻 国际新闻
  • 多对多:models.ManyToManyField() 定义在哪个类中都可以。
    例如:书籍类-作者类

应用场景

db_column='name'
primary_key=True
verbose_name='别名或者注释'
unique=True
null=True,blank=True
db_index=True 给表单建立索引
help_text='' 表单中显示帮助信息

一对一

  • 创建表
from django.db import models


# Create your models here.
class Account(models.Model):  # 账户信息
    id = models.AutoField(primary_key=True, verbose_name=u'用户id')
    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():
        # 指定表名,如果不指定则会将类名默认成表表名,并在前面加上app都名称
        db_table = 'Account'


# 一对一关系,每个账户都会有一个用户详情
class UserInfo(models.Model):  # 用户详细信息
    id = models.AutoField(primary_key=True)  # 用户id
    id_card = models.IntegerField()  # 身份证号
    addr = models.CharField(max_length=32)  # 家庭地址
    user = models.OneToOneField(to="Account", to_field="id", on_delete=models.CASCADE)
    # user作为外键,会被Django自动添加 "_id"来创建数据库中的列名,如果写成user_id ,则会在数据库展示user_id_id
    # 对于Django2.0版本,一对多(models.ForeignKey)和一对一(models.OneToOneField)要加上 on_delete=models.CASCADE 这个属性
    # on_delete=models.CASCADE 当Account中的一条数据被删除的时候,与之对应的UserInfo数据也会被删除

python manage.py makemigrations  #在app01/migrations下会生成数据迁移脚本
python manage.py migrate  #应用到db生成数据表
  • 增、删、改、查
from django.http import HttpResponse
from Applications.models import *
import datetime

# 获取当前年月日
yesterday = datetime.date.today() + datetime.timedelta(-1)


def add_user(request):
    # 添加一条数据
    # 先在主表中创建一条记录,并实例化对象
    detail_obj = Account.objects.create(username='15607241351', password='321321', register_date=yesterday)
    # 在详情表中添加一条记录,并将上面的实力赋值给外键
    UserInfo.objects.create(id_card='421281199512111717', addr='上海市.', user=detail_obj)

    return HttpResponse("增加数据成功")


def sel_user(request):
    #  查询 username 为15607241351 的 用户名与地址
    user_details = Account.objects.filter(username='15607241351').first()
    user_name = user_details.username  # 用户名
    user_addr = user_details.userinfo.addr  # 用户地址
    return HttpResponse("查询数据成功 username:%s,addr:%s" % (user_name, user_addr))


def update_user(request):
    # 将 username=15607241351 的 username 改为 15607241355
    Account.objects.filter(username='15607241351').update(username='15607241355')
    return HttpResponse("更新数据成功")


def del_user(request):
    # 删除username 为 15607241355的数据
    Account.objects.filter(username='15607241355').delete()
    return HttpResponse("删除数据成功")


一对多

  • 建表
# 这里用一个简单的博客举例,每篇文章会有一个或多个评论
class Blog(models.Model):
    '''
    博客
    '''
    id = models.AutoField(primary_key=True)
    title = models.CharField(max_length=100, verbose_name=u'标题')
    content = models.TextField(default='', verbose_name=u'正文')
    create_time = models.DateTimeField(verbose_name=u'创建时间')


class Comment(models.Model):
    '''
    评论 一个博客对应多条评论
    '''
    user_name = models.CharField(max_length=20, verbose_name=u'姓名')
    content = models.TextField(verbose_name=u'内容')
    create_time = models.DateTimeField(auto_now_add=True, verbose_name=u'创建时间')
    Blog = models.ForeignKey(to='Blog', to_field='id', on_delete=models.CASCADE, verbose_name=u'博客')

  • 增、删、改、查
# 一对多

def add_blog(request):
    # 增加文章
    blog_obj = Blog.objects.create(title='Django 一对多增加博客,并且增加评论', content='这是内容', create_time=yesterday)
    # 在文章下增加评论
    Comment.objects.create(user_name='别动我名字', content='文章很棒哦', Blog=blog_obj)

    Blog.objects.create(title='Django 一对多 增加博客,不增加评论', content='这是内容', create_time=yesterday)
    return HttpResponse('add_Blog~~')


def update_blog(request):
    # 更新文章
    Blog.objects.filter(title='Django 一对多增加博客,并且增加评论').update(title=' 更新 Django 一对多增加博客,并且增加评论')

    return HttpResponse('update_Blog')


def sel_blog(request):
    # 查询文章
    blog_content=Blog.objects.filter(title=' 更新 Django 一对多增加博客,并且增加评论')[0].content
    return HttpResponse('sel_Blog~~【 更新 Django 一对多增加博客,并且增加评论】的内容为: %s' % blog_content)


def del_blog(request):
    # 删除文章的时候会自动删除对应的评论
    Blog.objects.filter(title=' 更新 Django 一对多增加博客,并且增加评论').delete()
    return HttpResponse('del_Blog')


  • 多对对

待续…

相关文章

网友评论

    本文标题:Django 模型层 orm 多表操作

    本文链接:https://www.haomeiwen.com/subject/ywvdaqtx.html