# ###############基于对象查询(子查询)##############

一、对多查询

 正向查询

from django.shortcuts import render,HttpResponse
from app01 import models
# Create your views here. def query(request):
# ###############基于对象查询(子查询)##############
# 一对多查询 book-->publish
#正向查询:
# 查询python这本书的出版社的email邮箱.
python_obj = models.Book.objects.filter(title ='python').first()
print(python_obj.publish.email)
return HttpResponse(' OK')

  

# ###############基于对象查询(子查询)##############
# 正向查询按字段查询
# 一对多查询 book----------------------->publish
# <----------------------
#反向查询 book_set.all() 反向查询 反向查询#查询五道口出版社的书籍名称 pub_obj =models.Publish.objects.filter(name ='五道口出版社').last()
 for obj  in pub_obj.book_set.all():
print(obj.title) return HttpResponse(' OK')



二、多对多 查询


            # 按字段查询 正向查询(author.all())
# 多对多 book----------------------> author
# <----------------------
# book_set.all() 正向多对多查询
#查询python作者的年龄
python_obj =models.Book.objects.filter(title ='python').first()
print(python_obj)
for author in python_obj.authors.all():
print(author.name,author.age) return HttpResponse('ok')

输出结果

反向多对多 

  #查询 alex出版过的书籍
alex =models.Author.objects.filter(name ='哪吒').first()
for book in alex.book_set.all():
print(book.title) return HttpResponse('ok')

 三 、一对一的关系

author 于authordetail表的关系 。

一对一正向查询

反向查询

查询家在山东的作者名:

###############基于queryset和__查询(join的查询)####################

四 、

正向查询 : 按字段 

反向查询:按表名 

案例1 . 

#查询python这本书籍的出版社的邮箱

   python_obj = models.Book.objects.filter(title ='python').first()
    print(python_obj.publish.email)
    return HttpResponse(' OK')

  

案例2.   

 案例3 

两种方法

输出结果:

VIEWS文件 :

from django.shortcuts import render,HttpResponse
from app01 import models
# Create your views here. def query(request):
# ###############基于对象查询(子查询)##############
# 正向查询按字段查询
# 一对多查询 book----------------------->publish
# <----------------------
#反向查询 book_set.all()
# #正向查询:
#
# # 查询python这本书的出版社的email邮箱.
#
# python_obj = models.Book.objects.filter(title ='python').first()
# print(python_obj.publish.email) #f反向查询 按表明小写_set.all()
#查询五道口出版社的书籍名称
# pub_obj =models.Publish.objects.filter(name ='五道口出版社').last()
# for obj in pub_obj.book_set.all():
# print(obj.title) # 按字段查询 正向查询(author.all())
# 多对多 book----------------------> author
# <----------------------
# book_set.all()
#查询python作者的年龄
# python_obj =models.Book.objects.filter(title ='python').first()
# print(python_obj)
# for author in python_obj.authors.all():
# print(author.name,author.age) #查询 alex出版过的书籍
# alex =models.Author.objects.filter(name ='哪吒').first()
# for book in alex.book_set.all():
# print(book.title)
# # 按字段查询 正向查询(authordetail.all())
# 多对多 author----------------------> authordetail
# <----------------------
# 按表名 author #查询 哪吒的电话号码
nezhao_obj = models.Author.objects.filter(name ='哪吒').first()
print(nezhao_obj.authorDetail.telephone) # 反向查询
# 查询家在山东的作者名字
add_obj = models.AuthorDetail.objects.filter(addr ="山东").first()
print(add_obj.author.name) #############################基于queryset和__查询(join的查询)######################### #正向查询:按字段
#反向查询 :表名小写
#查询python这本书籍的出版社的邮箱
ret =models.Book.objects.filter(title ='python').values('publish__email')
print(ret ) #查询清华出版社的书籍名称
#方法1
qinghua_obj =models.Publish.objects.filter(name ='清华出版社').values('book__title')
print(qinghua_obj)
#方法2
qinghua_obj= models.Book.objects.filter(publish__name='清华出版社').values('title')
print(qinghua_obj) # 查询哪吒的手机号
ret = models.Author.objects.filter(name ='哪吒').values('authorDetail__telephone')
print(ret)
return HttpResponse('ok') #查询手机号 以 186开头的作者的出版过的书籍名称以及对应的出版社

  

2018.10.29日整理

from django.db import models

# Create your models here.

class Author(models.Model):
nid = models.AutoField(primary_key=True)
name=models.CharField( max_length=)
age=models.IntegerField() # 与AuthorDetail建立一对一的关系
authorDetail=models.OneToOneField(to="AuthorDetail",on_delete=models.CASCADE)
def __str__(self):
return self.name class AuthorDetail(models.Model): nid = models.AutoField(primary_key=True)
birthday=models.DateField()
telephone=models.BigIntegerField()
addr=models.CharField( max_length=) def __str__(self):
return self.addr class Publish(models.Model):
nid = models.AutoField(primary_key=True)
name=models.CharField( max_length=)
city=models.CharField( max_length=)
email=models.EmailField() def __str__(self):
return self.name class Book(models.Model): nid = models.AutoField(primary_key=True)
title = models.CharField( max_length=)
publishDate=models.DateField()
price=models.DecimalField(max_digits=,decimal_places=) # 与Publish建立一对多的关系,外键字段建立在多的一方
publish=models.ForeignKey(to="Publish",to_field="nid",on_delete=models.CASCADE)
# 与Author表建立多对多的关系,ManyToManyField可以建在两个模型中的任意一个,自动创建第三张表
authors=models.ManyToManyField(to='Author',)
def __str__(self):
return self.title

orm查询

from django.shortcuts import render,HttpResponse

# Create your views here.
from .models import *
def index(request):
#查询沙河出版社所有书籍的名称和价格(一对多)
ret = Publish.objects.filter(name="沙河出版社").values("book__title","book__price") #正向查询按字段,反向查询按表名.
print(ret)
#打印结果:<QuerySet [{'book__title': 'python入门', 'book__price': Decimal('100.00')}]>
"""
select book.title,book.price from Publish inner join book on Publish.pk =Book.pulish_id where publish.name ="沙河出版社"
"""
ret=Book.objects.filter(publish__name="沙河出版社").values("title","price")
print(ret)
#打印结果:<QuerySet [{'title': 'python入门', 'price': Decimal('100.00')}]> return HttpResponse("ok ")

  

day 81 天 ORM 操作复习总结的更多相关文章

  1. Django之ORM操作(重要)

    Django ORM操作 一般操作 看专业的官网文档,做专业的程序员! 必知必会13条   <1> all(): 查询所有结果 <2> get(**kwargs): 返回与所给 ...

  2. Django中的app及mysql数据库篇(ORM操作)

    Django常见命令 在Django的使用过程中需要使用命令让Django进行一些操作,例如创建Django项目.启动Django程序.创建新的APP.数据库迁移等. 创建Django项目 一把我们都 ...

  3. Django专题之ORM操作2

    Django ORM操作   目录 一般操作 看专业的官网文档,做专业的程序员! 回到顶部 必知必会13条 <1> all(): 查询所有结果 <2> get(**kwargs ...

  4. Python/Django(CBV/FBV/ORM操作)

    Python/Django(CBV/FBV/ORM操作) CBV:url对应的类(模式) ##====================================CBV操作============ ...

  5. python/ORM操作详解

    一.python/ORM操作详解 ===================增==================== models.UserInfo.objects.create(title='alex ...

  6. Django中ORM操作

    ORM操作: class UserInfo(models.Model): username = models.CharField(max_length=32) password = models.Ch ...

  7. Django的ORM操作

    ORM操作 select * from tb where id > 1 # 对应关系 models.tb.objects.filter(id__gt=1) models.tb.objects.f ...

  8. python 外键用法 多对多关系 ORM操作 模板相关

    一.app/models中写类(设计表结构) 1.普通类 class  A(models.Model): id=modles.AutoField(primary_key=True) name=mode ...

  9. Django之ORM操作

    Django之ORM操作 前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计 ...

随机推荐

  1. fragment 事务回滚 ---动态创建fragment

    import java.util.Date; import java.util.LinkedList; import com.qianfeng.gp08_day23_fragment5.fragmen ...

  2. TokuMX写操作无法加锁的问题

    问题: TokuMX删除文档时,符合删除条件的文档很多,删除操作持续时间长,期间,服务写操作OPS大幅下降,同时日志log里发现大量“ Lock not granted. Try restarting ...

  3. Spring框架的事务管理之基于AspectJ的XML方式(重点掌握)

    1. 步骤一:恢复转账开发环境(转账开发环境见“https://www.cnblogs.com/wyhluckdog/p/10137283.html”) 2.步骤二:引入AOP的开发包3.步骤三:引入 ...

  4. mysql中float、double、decimal三种类型,以及数值产生误差的原因

    单精度浮点数用4字节(32bit)表示浮点数,采用IEEE754标准的计算机浮点数,在内部是用二进制表示的,如:7.22用32位二进制是表示不下的,所以就导致不精确了,存取会出现误差. mysql中f ...

  5. Boolean.getBoolean用法

    相信很多人被Boolean.getBoolean(String name)欺骗过,想当然的认为它是将"true"或者"false"转换为Boolean类型的AP ...

  6. 模板练习(LUOGU)

    1:并查集 P3183食物链 #define man 300050 ; int find(int x){ if(fa[x]==x) return fa[x]; return fa[x]=find(fa ...

  7. Java数据结构和算法(一)概念

    Java数据结构和算法(一)概念 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 一.逻辑结构 数据之间的相互关系称为逻辑结构 ...

  8. CentOs7中的网卡配置工具

    CentOs7中的网卡配置工具 摘自:https://blog.51cto.com/13572810/2087991 misslaziness1人评论2715人阅读2018-03-17 22:09:1 ...

  9. linux下集成开发环境之ECLIPSE--在线调试、编译程序

    裸机开发流程 1.编写裸机程序:2.调试裸机程序:3.生成2进制映象(编译.链接.格式转换):4.烧写/运行2进制映象. 注意:我们自己开发的程序等等需要下载到开发板的Nandflash(类似于硬盘功 ...

  10. 2018.06.30 BZOJ1026: [SCOI2009]windy数(数位dp)

    1026: [SCOI2009]windy数 Time Limit: 1 Sec Memory Limit: 162 MB Description windy定义了一种windy数.不含前导零且相邻两 ...