Python框架篇之Django(Models的多表操作)

一对多

1、添加记录

 #publish_id=2
 Book.objects.create(name="Python进阶",price=77,pub_date="2019-12-12",publish_id=2)
            
#publish=object
Book.objects.create(name="GO",price=23,pub_date="2017-05-12",publish=publish_obj)

2、通过对象查询记录

#正向查询:
book_obj=Book.objects.get(name="python进阶")   
pub_obj=book_obj.publish----》书籍对象对应的出版社对象
pub_obj.name
#反向查询:
pub_obj = Publish.objects.filter(name="人民出版社")[0]
pub_obj.book_set.all().values("name","price")

3、通过filter查询记录(filter values 双下划线__)

 #人民出版社出版过的书籍与价格
ret=Book.objects.filter(publish__name="人民出版社").values("name","price")
                    
#python这本书出版社的名字
ret2=Publish.objects.filter(book__name="python进阶").values("name")
                    
#python这本书出版社的名字
ret3=Book.objects.filter(name="python").values("publish__name")
                    
#北京的出版社出版书的名字
ret4=Book.objects.filter(publish__city="北京").values("name")
                    
#2019年上半年出版过书的出版社的名字
ret5=Book.objects.filter(pub_date__lt="2019-07-01",pub_date__gt="2017-01-01").values("publish__name")
                    

多对多

1、创建多对多的关系 author= models.ManyToManyField(“Author”)(推荐)

2、书籍对象它的所有关联作者 obj=book_obj.authors.all()
绑定多对多的关系 obj.add(*QuerySet)
obj.remove(author_obj)

3、如果想向第三张表插入值的方式绑定关系: 手动创建第三张表

                        # class Book_Author(models.Model):
                        #     book=models.ForeignKey("Book")
                        #     author=models.ForeignKey("Author")                    
                        Book_Author.objects.create(book_id=2,author_id=3)

4、练习


#查询人民出版社出过的所有书籍名字和价格
    #方式一:
pub_obj=Publish.objects.filter(name="人民出版社")[0]
ret=Book.objects.filter(publish=pub_obj).values("name","price")
print(ret)

    #方式二
pub_obj = Publish.objects.filter(name="人民出版社")[0]
print(pub_obj.book_set.all().values("name","price"))
print(type(pub_obj.book_set.all()))

    #方式三:调用publish外键字段
ret=Book.objects.filter(publish__name="人民出版社").values("name","price")
print(ret)

#python这本书出版社的名字
ret2=Publish.objects.filter(book__name="python").values("name")
print(ret2)
ret3=Book.objects.filter(name="python").values("publish__name")
print(ret3)

ret4=Book.objects.filter(publish__city="北京").values("name")
print(ret4)

ret5=Book.objects.filter(pub_date__lt="2017-07-01",pub_date__gt="2017-01-01").values("publish__name")
print(ret5)




    #通过对象的方式绑定关系
book_obj=Book.objects.get(id=3)
print(book_obj.authors.all())
print(type(book_obj.authors.all()))

author_obj=Author.objects.get(id=2)
print(author_obj.book_set.all())


book_obj=Book.objects.get(id=3)
author_objs=Author.objects.all()
book_obj.authors.add(*author_objs)
book_obj.authors.remove(*author_objs)
book_obj.authors.remove(4)



    #创建第三张表
Book_Author.objects.create(book_id=2,author_id=2)

obj=Book.objects.get(id=2)
print(obj.book_author_set.all()[0].author)
展开阅读全文

Python数据分析与挖掘

01-08
92讲视频课+16大项目实战+源码+¥800元课程礼包+讲师社群1V1答疑+社群闭门分享会=99元   为什么学习数据分析?       人工智能、大数据时代有什么技能是可以运用在各种行业的?数据分析就是。       从海量数据中获得别人看不见的信息,创业者可以通过数据分析来优化产品,营销人员可以通过数据分析改进营销策略,产品经理可以通过数据分析洞察用户习惯,金融从业者可以通过数据分析规避投资风险,程序员可以通过数据分析进一步挖掘出数据价值,它和编程一样,本质上也是一个工具,通过数据来对现实事物进行分析和识别的能力。不管你从事什么行业,掌握了数据分析能力,往往在其岗位上更有竞争力。    本课程共包含五大模块: 一、先导篇: 通过分析数据分析师的一天,让学员了解全面了解成为一个数据分析师的所有必修功法,对数据分析师不在迷惑。   二、基础篇: 围绕Python基础语法介绍、数据预处理、数据可视化以及数据分析与挖掘......这些核心技能模块展开,帮助你快速而全面的掌握和了解成为一个数据分析师的所有必修功法。   三、数据采集篇: 通过网络爬虫实战解决数据分析的必经之路:数据从何来的问题,讲解常见的爬虫套路并利用三大实战帮助学员扎实数据采集能力,避免没有数据可分析的尴尬。   四、分析工具篇: 讲解数据分析避不开的科学计算库Numpy、数据分析工具Pandas及常见可视化工具Matplotlib。   五、算法篇: 算法是数据分析的精华,课程精选10大算法,包括分类、聚类、预测3大类型,每个算法都从原理和案例两个角度学习,让你不仅能用起来,了解原理,还能知道为什么这么做。
©️2020 CSDN 皮肤主题: 创作都市 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值