zoukankan      html  css  js  c++  java
  • Django ORM多表操作实际例子增删改查

    编写例子,代码如下

    class Book(models.Model):   #意见
        id = models.AutoField(primary_key=True)
        title = models.CharField(max_length=32)
        price = models.DecimalField(max_digits=8, decimal_places=2)
        publish = models.ForeignKey(to="Publish", to_field="pid", on_delete=models.CASCADE)
        author = models.ManyToManyField(to="Author")
    
    
    class Publish(models.Model):
        pid = models.AutoField(primary_key=True)
        name = models.CharField(max_length=32)
    
    
    class Author(models.Model):
        aid = models.AutoField(primary_key=True)
        name = models.CharField(max_length=32)
        age = models.IntegerField()
        author_detail = models.OneToOneField(to="Author_detail", to_field="aid", on_delete=models.CASCADE)
    
    
    class Author_detail(models.Model):  # 已建
        aid = models.AutoField(primary_key=True)
        add = models.CharField(max_length=32)
        city = models.CharField(max_length=32)
    

    对应关系图如下:

    多表之增加 代码示例

    
        models.Publish.objects.create(name="南京出版社")
        models.Publish.objects.create(name="北京出版社")
        models.Publish.objects.create(name="浙江出版社")
    
        # 新增作者详情表  Author_detail
        models.Author_detail.objects.create(add="鄞州区", city="宁波市")
        models.Author_detail.objects.create(add="余姚区", city="余姚市")
        models.Author_detail.objects.create(add="奉化区", city="奉化市")
        models.Author_detail.objects.create(add="温州区", city="温州市")
    
        # 新增作者表  Author
        au_detail = models.Author_detail.objects.filter(city="余姚市").first()
        au = models.Author.objects.create(name="blex", age=28, author_detail=au_detail)
        au = models.Author.objects.create(name="clex", age=38, author_detail_id=3)
        au = models.Author.objects.create(name="alex", age=18, author_detail_id=1)
    
        # 新增书籍表 Book
        pub = models.Publish.objects.filter(name="南京出版社").first()
        bk1 = models.Book.objects.create(title="python", price=18.23, publish_id=2)
        bk2 = models.Book.objects.create(title="java", price=28.23, publish=pub)
    
        # 新增书籍和作者多对多关系表  Book_author
        alex = models.Author.objects.filter(name="alex").first()
        blex = models.Author.objects.filter(name="blex").first()
        bk_author1 = bk1.author.add(*[alex, blex])
        bk_author2 = bk2.author.add(alex, blex)
        # 就是移除book title 是java的id,和author表id为1 的关联
        bk2.author.remove(1)
        # 就是移除book title 是java的id,和author表中alex,blex 的关联
        bk2.author.remove(*[alex, blex])
        # clear方法没有参数,会移出所有和java id关联的作者数据
        bk2.author.clear()
        # all这个方法可以查询多表关系中所有对应java这本书的作者
        bk = models.Book.objects.filter(title="java").first()
        print(bk.author.all())
    
    

  • 相关阅读:
    Silverlight中弹出网页
    Silverlight中嵌套html、swf、pdf
    silverlight 用户浏览器未安装SL插件问题
    silverlight视频、音频
    Silverlight形状、画笔、变换、图像处理、几何图形
    Silverlight动画学习笔记(三):缓动函数
    Silverlight动画的基本知识、关键帧动画
    Silverlight独立存储
    关于Silverlight调用天气预报接口问题
    c#获取今天星期几
  • 原文地址:https://www.cnblogs.com/Young-shi/p/15157490.html
Copyright © 2011-2022 走看看