当前位置: 首页 > news >正文

pyDAL一个python的ORM(9) pyDAL的嵌套查询

假设有以下两个表:

db.define_table('person',Field('id', 'string'), Field(‘name', 'string'), Field(‘dept', 'string'))

db.define_table('things',Field('id', 'string'), Field(‘name', 'string'), Field(‘owner', 'string'))

一、使用belongs进行嵌套查询

我们查询要求:things表中属于marketing部门的东西:

前边我们已经提到,belongs还可以用作嵌套查询

rows = db(db.things.owner.belongs(db(db.person.dept == 'marketing')._select(db.person.name))).select()

红色部分就是一个嵌套,嵌套的select前记得加一个下划线_,

二、更清晰的书写规则

为了嵌套的条件更清晰,我们也可以这样书写,把嵌套单独拧出来写

owers = db(db.person.dept == 'marketing')._select(db.person.name)

rows = db(db.things.owner.belongs(owers)).select()

三、多重嵌套

当然有多个表时,可以多嵌套,假如还有一个表,

db.define_table('vendor',Field('id', 'string'), Field(‘name', 'string'), Field(‘sku', 'string'))

我们要查询marketing部门人员的东西的生产商:

owers = db(db.person.dept == 'marketing')._select(db.person.name)

things = db(db.things.owner.belongs(owers))._select(db.things.name)

vendors = db(db.vendor.sku.belongs(things)).select()

http://www.lryc.cn/news/279741.html

相关文章:

  • 融资项目——EasyExcel操作Excel文件
  • OAI openair3-NAS-UE-EMM代码解读(续)
  • SQL-条件查询与聚合函数的使用
  • Qt移植曲线显示
  • 基于springboot生鲜交易系统源码和论文
  • vue中鼠标拖动触发滚动条的移动
  • 1、理解Transformer:革新自然语言处理的模型
  • Acwing847 图中点的层次(bfs)
  • windows11通过虚拟机安装Ubuntu20.04
  • 时序预测 | Matlab实现EEMD-SSA-BiLSTM、EEMD-BiLSTM、SSA-BiLSTM、BiLSTM时序预测对比
  • Android14之解决Pixel手机联网出现感叹号(一百八十)
  • Vmware虚拟机问题解决方案 运行虚拟机系统蓝屏 运行虚拟机时报错VT-x
  • uni-app中轮播图实现大图预览
  • 了解什么是UV纹理?
  • 【蓝桥备赛】wzy的数组Ⅱ——简单莫队问题
  • 学习Qt笔记
  • pymssql 报错误解决办法:20002, severity 9
  • Web缓存代理
  • Rust-模式解构
  • C#基于ScottPlot进行可视化
  • 基于JAVA+ssm开发的在线报名系统设计与实现【附源码】
  • 蓝桥——第 3 场 小白入门赛(A-D)
  • Java项目:06 Springboot的进销存管理系统
  • 数据结构与算法之美学习笔记:47 | 向量空间:如何实现一个简单的音乐推荐系统?
  • 5《Linux》
  • go-carbon v2.3.5 发布,轻量级、语义化、对开发者友好的 golang 时间处理库
  • VQ-VAE(Neural Discrete Representation Learning)论文解读及实现
  • OpenAI的ChatGPT:引领人工智能交流的未来
  • es集群安装及优化
  • 【开源】基于JAVA+Vue+SpringBoot的医院门诊预约挂号系统