以下是一个简单的示例代码,演示如何在云函数中使用 db.Geo 构建地理位置查询条件:
// 云函数入口文件
const cloud = require('wx-server-sdk')
cloud.init()
const db = cloud.database()
const collection = db.collection('your_collection_name')
// 云函数入口函数
exports.main = async (event, context) => {
try {
// 使用 db.Geo.Point 构建地理位置点
const point = new db.Geo.Point(event.longitude, event.latitude)
// 使用地理位置点进行附近的位置查询
const result = await collection.where({
location: db.Geo
.near({
geometry: point,
maxDistance: 1000, // 查询半径,单位为米
})
}).get()
// result.data 包含了附近位置的记录
return result.data
} catch (err) {
console.error(err)
return err
}
}
在上述代码中,db.Geo.Point 用于构建一个地理位置点对象,然后使用 db.Geo.near 构建一个附近的位置查询条件。在示例中,查询的半径为 1000 米,你可以根据实际需求调整查询条件。
请注意,使用地理位置查询条件时,确保你的集合中有一个字段存储了地理位置信息,并且已经创建了地理位置的索引。在小程序云开发控制台的数据库界面中,你可以通过设置字段类型为 "地理位置" 来创建地理位置字段,并在查询条件中使用 where 进行地理位置的查询。
这个示例中进行了附近的位置查询,你可以根据实际需求调整地理位置查询的条件。
转载请注明出处:http://www.pingtaimeng.com/article/detail/1206/微信小程序