ORM表之间的多对多处理

1.ORM多对多语法

  1.book = models.ManyToManyField(to='Book')

  2.优势

    1.帮助我们自动创建了第三张表

    2.提供了很多方便的关联方法

      1.author_obj.book.all()      -->查询作者所有关联的所有书籍

      2.author_obj.book.add(id1,id2)   -->给作者添加新关联的书籍

      3.author_obj.book.set(id1,id2)    -->给作者修改关联的书籍

2.作者表的增删改查

  1.查

    1.author_obj.book.all()

    2.在Django模板语言中,不需要加括号{{ author_obj.book.all }},html会自动进行反射

  2.增

    1.add(*[])    -->使用author_obj.book.getlist()获取数据时,得到的是一个列表

  3.删除

    1.author_obj.book.filter(过滤条件).delete()

    2.补充Django2.0以上的版本,外键需要手动设置级关联操作 on_delete=models.CASCADE

  4.修改

    1.set([])

转载于:https://www.cnblogs.com/lijinming110/p/9898334.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值