关于Django中ORM之增的多种方式-创新互联
创新互联www.cdcxhl.cn八线动态BGP香港云服务器提供商,新人活动买多久送多久,划算不套路!
创新互联公司基于分布式IDC数据中心构建的平台为众多户提供温江服务器租用 四川大带宽租用 成都机柜租用 成都服务器租用。这篇文章主要介绍关于Django中ORM之增的多种方式,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
Django中的ORM之增:
1、使用create方式
方式一:
Publish.objects.create("name"="人民出版社",city="北京"}
方式二:
Publish.objects.create(**{"name":"文艺出版社","city":"上海"}}
2、使用save方式
方式一:
book1=Book(title="python",price="88",publish_id="1",publication_date="2017-06-18") book1.save()
方式二:
author1=Author(name="jerry") author1.save()
3、一对多的信息的创建
方式一:
#获取出版社对象publish_obj=Publish.objects.get(id=4) #将出版社的对象绑定到书籍的记录中Book.objects.create( title="python", price=48.00, publication_date="2017-07-12", publish=publish_obj, )
方式二:
#直接把出版社的id号插入到书籍的记录中Book.objects.create( title="python", price=48.00, publish_id=2, publication_date="2017-06-18", )
4、多对多信息的创建
为一本书添加多个作者
author1=Author.objects.get(id=1)#获取id号为1的作者对象 author2=Author.objects.filter(name="tom")#获取名字为"tom"的作者对象 book1=Book.objects.get(id=2)#获取id号为2的书籍对象 book1.authors.add(author1,author2)#为书籍对象添加多个作者对象
也可以用这种方式:
book1.authors.add(*[author1,author2])#为书籍对象添加作者对象的列表 book1.authors.remove(*[author1,author2])#删除指定书籍的所有作者
为一个作者添加多本书
author_obj = Author.objects.filter(name="jerry")#获取名字为"jerry"的作者对象 book_obj=Book.objects.filter(id__gt=3)#获取id大于3的书籍对象集合 author_obj.book_set.add(*book_obj)#为作者对象添加书籍对象集合 author_obj.book_set.remove(*book_obj)#删除指定作者对象所有的书籍
手动创建多对多的作者与书籍信息表
class Book2Author(models.Models): author=models.ForeignKey("Author")#为作者指定Author这张表做为外键 book=models.ForeignKey("Book")#为书籍指定Book这张表做为外键 author_obj=models.Author.objects.filter(id=3)[0]#获取Author表中id为3的作者对象 book_obj=models.Book.objects.filter(id=4)[0]#获取Book表中id为4的书籍对象
方式一:
obj1=Book2Author.objects.create(author=author_obj,book=book_obj) obj1.save()
方式二:
obj2=Book2Author(author=author_obj,book=book_obj) obj2.save()
以上是关于Django中ORM之增的多种方式的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联-成都网站建设公司行业资讯频道!
新闻名称:关于Django中ORM之增的多种方式-创新互联
链接地址:http://lswzjz.com/article/gshjg.html