在微信小程序云开发的数据库查询操作中,db.command 对象提供了数组操作符和地理位置操作符,用于构建查询条件中的数组和地理位置的操作。以下是一些常见的数组和地理位置操作符的示例:

数组操作符:

1. 数组包含操作符:
const db = wx.cloud.database();
const collection = db.collection('example');

// 数组包含操作符
collection.where({
  arrayField: db.command.in([1, 2, 3])
}).get()
  .then(res => {
    console.log(res);
  })
  .catch(err => {
    console.error(err);
  });

在上述示例中,使用 db.command.in 表示数组包含操作符,查询满足 arrayField 包含 1、2 或 3 的文档。

2. 数组不包含操作符:
const db = wx.cloud.database();
const collection = db.collection('example');

// 数组不包含操作符
collection.where({
  arrayField: db.command.nin([4, 5, 6])
}).get()
  .then(res => {
    console.log(res);
  })
  .catch(err => {
    console.error(err);
  });

在上述示例中,使用 db.command.nin 表示数组不包含操作符,查询满足 arrayField 不包含 4、5 或 6 的文档。

3. 数组所有元素满足条件操作符:
const db = wx.cloud.database();
const collection = db.collection('example');

// 数组所有元素满足条件操作符
collection.where({
  arrayField: db.command.all([1, 2, 3])
}).get()
  .then(res => {
    console.log(res);
  })
  .catch(err => {
    console.error(err);
  });

在上述示例中,使用 db.command.all 表示数组所有元素满足条件操作符,查询满足 arrayField 的所有元素都包含在 [1, 2, 3] 中的文档。

更多数组操作符的详细信息请参考[微信小程序云开发官方文档 - 数据库 - Command - 数组操作符](https://developers.weixin.qq.com/miniprogram/dev/wxcloud/guide/database/command.html#%E6%95%B0%E7%BB%84%E6%93%8D%E4%BD%9C%E7%AC%A6)。

地理位置操作符:

1. 地理位置包含在某个区域内操作符:
const db = wx.cloud.database();
const collection = db.collection('example');

// 地理位置包含在某个区域内操作符
collection.where({
  location: db.command.geoWithin({
    geometry: db.Geo.LineString([
      [0, 0],
      [0, 10],
      [10, 10],
      [10, 0],
      [0, 0]
    ])
  })
}).get()
  .then(res => {
    console.log(res);
  })
  .catch(err => {
    console.error(err);
  });

在上述示例中,使用 db.command.geoWithin 表示地理位置包含在某个区域内操作符,查询满足 location 在指定的线区域内的文档。

2. 地理位置在某个区域的外部操作符:
const db = wx.cloud.database();
const collection = db.collection('example');

// 地理位置在某个区域的外部操作符
collection.where({
  location: db.command.geoIntersects({
    geometry: db.Geo.Polygon([
      [0, 0],
      [0, 10],
      [10, 10],
      [10, 0],
      [0, 0]
    ])
  })
}).get()
  .then(res => {
    console.log(res);
  })
  .catch(err => {
    console.error(err);
  });

在上述示例中,使用 db.command.geoIntersects 表示地理位置在某个区域的外部操作符,查询满足 location 在指定的多边形区域外的文档。

更多地理位置操作符的详细信息请参考[微信小程序云开发官方文档 - 数据库 - Command - 地理位置操作符](https://developers.weixin.qq.com/miniprogram/dev/wxcloud/guide/database/command.html#%E5%9C%B0%E7%90%86%E4%BD%8D%E7%BD%AE%E6%93%8D%E4%BD%9C%E7%AC%A6)。


转载请注明出处:http://www.pingtaimeng.com/article/detail/1286/微信小程序