首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

一篇文章带你了解Django ORM操作(高端篇)

通过研究表结构发现,每出版的书,都在book表中记录,并且每本书会外键一个出版社id。 ? 如果我们能对出版社id进行压缩,然后再求出压缩出版社id里面对应的数量。 啧啧,这不就出来了吗?...分组获取外键字段信息 上述确实可以通过分组实现了功能。 但是上述只能获取出版社id,并不能获取出版社名啥的,但是如何获取压缩外键字段详细信息呢?...注:分组(annotate)后面跟的values。 里面只能写外键字段的列和annotate里面的列,不能写其他。 如果分组分的不是外键字段,那就不能再跟values!...分组再筛选 分组再筛选本质就是原生sql的group by .. having,将压缩完的数据在进行条件判断。 但是对压缩的数据进行判断只能通过having。...本篇主要补充的是一些高端操作,例如聚合操作,分组操作,分组再筛选操作,F查询和Q查询。 如何动态构造Q查询。 相对来说,Django还是自由度比价高的,而且写起来确实比较省心。

1.3K11

Django 1.10中文文档-第一个应用Part7-自定义管理站点

Django在admin站点中,自动地将所有的外键关系展示为一个select框。在我们的例子中,目前只有一个question对象存在。 请注意图中的绿色加号,它连接到Question模型。...每一个包含外键关系的对象都会有这个绿色加号。点击它,会弹出一个新增Question的表单,类似Question自己的添加表单。...填入相关信息点击保存后,Django自动将该Question保存在数据库,并作为当前Choice的关联外键对象。通俗讲就是,新建一个Question并作为当前Choice的外键。...过滤器显示的筛选类型取决与你过滤的字段,由于pub_data是DateTimeField,所以Django就自动给出了“今天”、“过去7天”、“本月”、“今年”这几个选项。 这一切进展顺利。...该变量包含了所有已经安装的Django应用。你可以硬编码链接到指定对象的admin页面,使用任何你认为好的方法,用于替代这个app_list。

3.6K60
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    day67-Django进阶-ORM操作数据库+django环境搬运

    1.如何新建Django超级用户 [在终端输入 python manage.py createsuperuser 依次输入用户名密码] [项目启动后,访问 /admin/ ,输入用户名密码]...Meta 01.3 配置库.png 6.如何搬运Django环境,在一个py文件里面实现ORM操作 from app01 import xx 只能写在 django.set_up() 后面 image.png...image.png 13.多对多 + 一对多 add() 一对多 # 将 QuerySet 里的所有对象外键全部强行指向当前查询对象 books = models.Book.objects.filter...) add() 多对多 # 将 QuerySet 里面的对象保留已有外键,新增指向自己的外键 # add 需要打散 books = models.Book.objects.filter(id__gte=...,即外键指向可以为空 remove() 一对多,多对多都一样 # 接收QuerySst,先筛选出符合条件的要删除的对象 # 打散出入对象,并不解除所有,只解除筛选出的对象 books = models.Book.objects.filter

    55900

    Mysql基础

    它对数据库进行统一的管理和控制,以保证数据库的安全性和完整性。用户通过DBMS访问数据库中的数据,数据库管理员也通过dbms进行数据库的维护工作。...该节描述了这些类型如何工作以及如何在查询中使用这些类型。 ? CHAR和VARCHAR类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。...-- 按位置字段筛选 select * from order_menu group by 5; -- 练习:对购物表按类名分组后显示每一组商品的价格总和...语句 --外键约束对子表的含义: 如果在父表中找不到候选键,则不允许在子表上进行insert/update --外键约束对父表的含义: 在父表上进行update/delete以更新或删除在子表中有一条或多条对...-- 应匹配行的候选键时,父表的行为取决于:在定义子表的外键时指定的 -- on update/on delete子句

    4.2K20

    django 1.8 官方文档翻译: 2-2-1 执行查询

    如果你要执行更复杂的查询(比如,实现筛选条件的 OR 关系),可以使用 Q 对象。 Q 对象(django.db.models.Q)是用来封装一组查询关键字的对象。...在 Django 删除对象时,会模仿 SQL 约束 ON DELETE CASCADE 的行为,换句话说,删除一个对象时也会删除与它相关联的外键对象。...一对多关系 正向 如果一个 model 有一个 ForeignKey字段,我们只要通过使用关联 model 的名称就可以得到相关联的外键对象。...你可以设置和获得外键属性。正如你所期望的,改变外键的行为并不引发数据库操作,直到你调用 save()方法时,才会保存到数据库。...逆向关联 如果 model 有一个 ForeignKey外键字段,那么外联 model 的实例可以通过访问 Manager 来得到所有相关联的源 model 的实例。

    4.4K20

    django后台管理-admin

    0922自我总结 django后台管理-admin 一.模型注册 admin.py 注册方式一: #在对于注册的app中的admin文件中导入模型然后注册模型 admin.site.register(导入的模型类...) 注册方式二该方法是Django1.7的版本新增的功能: from django.contrib import admin from blog.models import Blog #Blog模型的管理器...list_editable 设置默认可编辑字段 list_editable = ['machine_room_id', 'temperature'] #fk_fields 设置显示外键字段...fk_fields = ('machine_room_id',) 2、筛选器 from django.contrib import admin from blog.models import...一般ManyToManyField多对多字段用过滤器;标题等文本字段用搜索框;日期时间用分层筛选。 过滤器如果是外键需要遵循这样的语法:本表字段__外键表要显示的字段。

    88910

    Django admin 一些有用的设置

    list_editable 设置默认可编辑字段     list_editable = ['machine_room_id', 'temperature']        #fk_fields 设置显示外键字段...筛选器是Django后台管理重要的功能之一,而且Django为我们提供了一些实用的筛选器。...一般ManyToManyField多对多字段用过滤器;标题等文本字段用搜索框;日期时间用分层筛选。 过滤器如果是外键需要遵循这样的语法:本表字段__外键表要显示的字段。...唯一的区别就是 这种方法 是登录http://ip/admin/  站点和用户组在一起 ? 而第一种方法是分开的。 5.通过当前登录的用户过滤显示的数据 官方文档的介绍: ?...我们如何修改这个app的名称达到定制的要求呢,其实Django已经在文档里进行了说明。 从Django1.7以后不再使用app_label,修改app相关需要使用AppConfig。

    2.6K70

    Django 外键引用另一个表中的多个字段

    在 Django 中,外键(ForeignKey)通常只引用另一张表的一个字段,比如一个主键或一个唯一标识字段。然而,如果我们需要让一个外键引用另一张表中的多个字段,通常有以下几种方法来实现这种关系。...1、问题背景在 Django 中,模型之间的关系通常使用外键(ForeignKey)来建立。外键允许一个模型中的字段引用另一个模型中的主键。然而,有时我们需要在一个模型中引用另一个模型中的多个字段。...以下是如何在 Django 中使用复合主键来实现外键引用另一个表中的多个字段:在 product_models 模型中,添加一个 id 字段作为主键:class product_models(models.Model...以下是如何在 Django 中使用複合鍵的示例:# Get the product model with the specified nameproduct = product_models.objects.get...划重点Django 不直接支持复合外键,但可以通过添加唯一约束、使用中间表或在查询中使用逻辑约束来实现类似效果。

    10610

    Python Web 深度学习实用指南:第三部分

    首先,让我们了解 DialogFlow 生态系统的几个组件如何与下图交互: [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-cTzuWAvC-1681705088846)(...设置视觉客户端库 Cloud Vision API 可通过一组适用于不同语言的库(称为 Vision Client 库)获得。...Azure 提供的深度学习服务一览 Azure 的基于深度学习(和通用机器学习)的产品大致分为三个部分: Azure 机器学习服务,它提供端到端的机器学习生命周期,包括模型构建,训练和部署: [外链图片转存失败...这是一个非常好的值,我们将继续保存模型并通过 Django 使用它。...我们了解了如何保存模型,然后通过基于 Django 的 Web 应用以 API 的形式部署模型。

    15.1K10

    Python Web 深度学习实用指南:第四部分

    根据用户的首选项(现在称为输入特征首选项),系统将提供最符合其首选项的产品列表。 因此,长话短说,问题陈述可以写为: “给定一组输入特征(用户偏好),我们的任务是建议产品列表。”...考虑到这些首选项,我们的系统将预测一组最合适的产品。 这是 DL 部分发挥作用的地方。...这是原始的问题陈述: “给定一组输入特征(用户偏好),我们的任务是建议产品列表。” 如果推荐不合格产品,用户将不会喜欢我们的系统。...通常,通过参考文档或公司在其网站上提供的一组常见问题解答,可以轻松回答客户提出的问题,但是客户通常不会仔细阅读它们。...为链接到 Dialogflow 智能体的项目创建一个新的服务密钥,如下所示: [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vQKBE8XS-1681705163559)

    6.9K10

    Django_rest框架电商项目实践项目(一篇文章讲清楚电商项目)项目的创建与基本的配置,所有接口的代码,项目代码已给

    ,需要排序 根据生产厂商进行选择 view url 前段传参 商品的详情 view url 前端如何传参 查询的外键需要返回具体的name值,而不是id 第一种方法 第二种方法 实现用户的登录 用户的详情...search=华为手机01 商品分类查询 因为商品表里面有一个外键,就是产品的分类 view代码 class ProductListByCategoryView(generics.ListAPIView...if category is not None: queryset = Product.objects.filter(category=category) # 根据产品分类进行筛选查询...pk 前端如何传参 查询的外键需要返回具体的name值,而不是id 第一种方法 class ProductRetrieveSerializer(serializers.ModelSerializer...这个表有一个外键和用户关联。

    2.8K10

    用python搭建一个校园维基网站(二)—— 可编辑内容的首页的创建

    1、manage.py是Django项目通用的管理脚本(通过python manage.py 某命令参数使用)。...我们的WikiHome页面模型中需要图中红色高亮的一系列字段,其中title字段继承自Page类,不用额外添加,image字段为连接到wagtailimages.Image模型的外键。...还包含了一个wagtail提供的对ForeignKey进行了一层封装的ParentalKey外键连接到它所属的WikiHome页面。类似的,panels表明出现在可编辑区。 ? ?...WikiHomeTopLink类似,为了层次上更清晰,采用了多重继承,在models.py中只定义ParentalKey外键,而在另一个文件中定义了RelatedLink模型,包含的字段有链接文本和具体链接...,只是具体链接可能为外链、某个页面或某个文档,占用了三个字段,此外还利用@property装饰器为该模型添加了link属性,来返回它的具体链接,这样在模板中就可以使用.link调用。

    3.6K80

    Django从1.8升级到2.0注意事项 转

    原文照搬: 由于Django的产品周期问题,我们决定将Django从当前开发的1.8版本升级到2.0版本,此新最版本已不再支持python2,所以开发语言也需要相应升级到3.6版本。...其间几个重要的变更技术点节录如下(以更改过程为主,不区别django还是python变更,且django中的变化也不一样是2.0中才开始具有的): ?...不再是默认选项,需要显性指定 # 表示外键关联到作者表,当作者表删除了该条数据,图书表中不删除,仅仅是把外键置空 author = models.ForeignKey(AuthModel, null...11,html输出时,byte如何转换成unicode?...如果安装好新版python3解释之后,通过更改active文件中的路径,可以实现拷贝目录通用.

    92710

    Django模型

    外键 外键这个东西,通常都是在业务逻辑层面来实现的,而不是在数据库中实现。但是通常大家学习的数据库课程中,都会有数据库设计范式,其中有个第三范式就是专指的外键约束。在这里只是简单的介绍一下。...下面是另外一个模型,和前面的BookInfo模型通过外键关联起来。...choices参数就是从我们定义的二元组(GENDER_CHOICES)中获取值。二元组的第一个值会储存在数据库中,而第二个值将只会用于在表单中显示。...外键:通过使用models.ForeignKey来设置外键,ForeignKey的第一个参数是要关联的模型类名,第二个参数是on_delete。...它的常用值可以如下: CASCADE级联,删除主表数据时连通一起删除外键表中数据 PROTECT保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据 SET_NULL设置为NULL

    1.9K20

    一篇文章带你了解Django ORM操作(进阶篇)

    回顾 上次咱们学习了一下Django ORM的基本查询操作。 查询操作主要使用的是filter()方法。...Django ORM的查询还有很多,继续来看叭!!! 查询操作 对象.外键字段 比如,我们拿到了一个书的信息,我们可以这样打印他的信息。...注:蓝色为外键字段 不知道你有没有疑问,为什么book.publish会把邮电出版社打印出来。 这个原因主要在于外键对象的__str__方法。 ?...总结 对象.外键字段拿到的就是外键字段对象,直接就可以通过对象.外键字段.外键属性获取具体值。 反向查询(表名__set.all()) 上述我们是通过正向查询的方式查询到了书对应的出版社具体信息。...上文我们说过,是支持多个filter的,filter().filter()... 这种情况通常用于不确定筛选条件,但是多层筛选的情况下。

    47411

    如何使用 Django 更新模型字段(包括外键字段)

    本教程将详细介绍如何通过 Django 更新模型字段,重点讨论了解决外键字段更新的方法,特别是使用 attrs 方式的实现。1. 简介Django 中的模型是应用程序中管理数据的核心部分。...每个成绩记录都关联到一个学生,通过 student 外键字段与学生表建立联系。3. 更新方法探讨在 Django 中,更新模型字段的方法有几种。...下面我们详细探讨这种更新方式:使用 attrs 方式更新外键字段在 Django 中,可以直接通过设置外键字段的方式来更新模型中的外键关联。...然而,需要注意的是,update() 方法不支持直接更新外键关联的对象或外键字段。因此,在更新涉及外键字段的情况下,仍需要通过设置外键字段的方式来进行操作。...总结与实践建议在本教程中,我们深入探讨了如何使用 Django 更新模型字段,特别是处理外键字段更新的方法。

    28310

    【22】进大厂必须掌握的面试题-30个Informatica面试

    Source Qualifier可以联接来自同一源数据库的数据。通过将源链接到一个Source Qualifier转换,我们可以将两个或多个具有主键-外键关系的表连接起来。...null*** RTR –路由器转换两组 组1连接到TGT_NULL(表达式O_FLAG =’NULL’) 组2连接到TGT_NOT_NULL(表达式O_FLAG =’NNULL’) 11.如何通过映射流将备用记录加载到不同的表中...存在三种不同的数据模型。 星型模式 ? 在这里,销售事实表是事实表,每个维表的代理键在这里都是通过外键引用的。示例:时间键,项目键,分支键,位置键。事实表被维表(例如分支,位置,时间和项目)包围。...星型模式中的集中表称为事实表。事实表通常包含两种类型的列。包含度量的列称为事实和列,它们是维表的外键。事实表的主键通常是由维表的外键组成的组合键。...例如:仅包含产品密钥和日期密钥的事实表是事实。该表中没有度量。但是您仍然可以获得一段时间内出售的产品数量。 包含汇总事实的事实表通常称为摘要表。 25.通过映射详细说明SCD TYPE 1。

    6.7K40
    领券