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