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

官方网站内容更新需要怎么做哪里有软件开发培训机构

官方网站内容更新需要怎么做,哪里有软件开发培训机构,创业谷网站建设方案,仿新浪全站网站源码多表查询场景介绍 一种很常见的场景,比如电商首页中,需要同时展示最近比较火热的店铺,以及直接展示店铺里对应的商品。或者用户下单之后购物车里可以看到所选的商品以及对应的店铺。如果不知道如何用mongodb自带的查询语句快速查询的话&#…

多表查询场景介绍

        一种很常见的场景,比如电商首页中,需要同时展示最近比较火热的店铺,以及直接展示店铺里对应的商品。或者用户下单之后购物车里可以看到所选的商品以及对应的店铺。如果不知道如何用mongodb自带的查询语句快速查询的话,我们能有的实现方案,可能是先查询店铺,然后通过for循环再查询店铺里的商品,而for循环是会反复操作数据库,对性能有极大的损耗,并且速度也非常的慢,所以这里我们来学习一下如何用mongodb来多表查询。

多表查询操作

aggregate集合函数与$lookup的使用

一下以疾病分类与对应的产品表为例代码如下:

db.disease_type.aggregate([{$lookup: {from: 'product',localField: '_id',foreignField: 'disease_type_id',as: 'products',},}])

aggregate为集合函数

$lookup 操作符将多个文档合并为一个数组

from 则为要被关联查询的表,比如的product则为产品表

localField 为当前表的id,也就是disease_type表的id

foreignField 为被关联表的要与当前表对应的id,也就是product的disease_type_id自带与disease_type表的_id字段进行关联

as 则是将这个被关联的表存放到那个字段中。

整个数据结构会自动拼接好,最终结果如下图,

$unwind数据结构与$project数据过滤

如果每个产品都对应一个分类,则用unwind改变数据结构代码如下:

db.disease_type.aggregate([{$lookup: {from: 'product',localField: '_id',foreignField: 'disease_type_id',as: 'products',}},{$unwind:"$products"},{$project: {_id: 1,date: 1,products: {_id: 1,name: 1,price: 1,}}}])

注意这里的products名称必须与上面的as要一致,否则也会找不到结果。

而$project则是过滤字段,只展示指定的内容。如果想展示所有则去掉此属性即可。

结果如下:

$map自定义结构

$project可以配置要展示的哪些字段,但有时候字段的名称可能要修改调整一下。比如_id改为id或者可自己配置各种结构

db.disease_type.aggregate([{$lookup: {from: 'product',localField: '_id',foreignField: 'disease_type_id',as: 'products',}},{$project: {_id: 1,date: 1,products: {$map: {input: '$products',as: 'product',in: {_id: '$$product._id',parentId:"$products._id",name: '$$product.name',price: '$$product.price',}}}}}])

$map 重新遍历循环

input 里的$products则表示商品表数据

as 里的product则表示被遍历的每个数据(类似for(item in products))。而只要被as处理之后,就可以通过$$product的方式调用这个变量了。

in 则表示商品列表内部结构的配置,比如还需配置parentId,这里的name,price等key字段都可以自己重命名,要绑定的字段则可通过$$product来绑定。

如下图

分页与模糊查询

        以上功能都是查询的所有数据,但我们实际运用中还需要分页或者通过关键字筛选。可继续在数组里添加其他条件,代码如下

db.disease_type.aggregate([{$lookup: {from: 'disease',localField: '_id',foreignField: 'disease_type_id',as: 'products',},},{$unwind: '$products'},{$match: {'products.name': {$regex: name,$options: 'i'},},},{$skip: start,},{$limit: limit,}])

$match 则是对某些字段添加过滤条件,而里面的$regex则表示用正则去匹配

$skip与$limit 则表示从那段开始过滤后面多少条数据

mongoose插件调用

创建表model

let nodeSchema = new mongoose.Schema(config);
client = mongoose.model('disease_type', nodeSchema, 'disease_type');

执行mongo语句

 client.aggregate([{$lookup: {from: 'disease',localField: '_id',foreignField: 'disease_type_id',as: 'products',},},{$unwind: '$products'},{$match: {'products.name': {$regex: name,$options: 'i'},},},{$skip: start,},{$limit: limit,}]).exec((err, result) => {if (err) {console.error(err);response.error(ctx, err)return;}console.log(result);response.success(ctx, result)});

exec函数则会将查询到的结果数据返回给result

http://www.yayakq.cn/news/655604/

相关文章:

  • 电子商务网站建设与运营 说课福永招聘网站建设
  • 网站是哪个公司做的兰州市住房和城乡建设局网站
  • 方圆网站建设孝感做网站xgsh
  • 给网站做翻译建设工程规范发布网站
  • 简述网站建设的基本流程深圳市建设执业培训中心网站
  • 做内贸要在哪个网站找客户不是搜索网站的是
  • 怎样做艾条艾柱网站网站建设与制作软件
  • 东莞网站建设五金建材wordpress除了首页全是404
  • 外贸网站建设 惠州东莞vi设计公司排名
  • 网站富文本的内容怎么做怎样在网上做环保设备网站
  • 宁波网站建设制作电话号码网站开发时间安排
  • 学院网站建设自媒体营销推广
  • 东城网站建设哪家好php 做网站 python
  • 品牌网站设计方案自己做网站是用什么软件
  • 网站服务器是指什么手机门户网站建设
  • 企业网站建设 属于什么费用wordpress字体编辑插件下载
  • 阜阳微商城网站建设苏州专业做网站公司电话
  • 大沥网站建设公司域名搭建网站
  • 网站建设的原则 流程上海出大事啦
  • 徐州h5建站模板陕西网站建设
  • 网站模板 商标国内好用的搜索引擎
  • 找装修济南 网站优化
  • 傻瓜做网站用什么软件南宁定制网站制作电话
  • 网站销售需要什么手续微信文章导入wordpress
  • 企业网站制作建设的框架有哪几种网站建设项目中标通知
  • 响应式网站栅格网站开发三个月能学会吗
  • 九江做网站的公司建设银行培训网站
  • 合肥网站 技术支持 上诚科技网站说服力营销型网站策划
  • wordpress清空文章备份并对齐id兰州网络优化
  • 网站开发课程的心得wordpress教程 aliyun