云数据库:

云数据库提供高性能的数据库写入和查询服务。通过腾讯云开发(Tencent CloudBase.TCB)的SDK,可以直接在客户端对数据进行读写,也可以在云函数中读写数据,还可以通过控制台对数据进行可视化的增、删、查、改等操作。微信小程序云开发所使用的数据库本质上就是一MongoDB数据库。MongoDB数据库是介于关系数据库和非关系数据库之间的产品:是非关系数据库中功能最丰富、最像关系数据库的。
数据库:默认情况下,云开发的函数可以使用当前环境对应的数据库。可以根据需要使用不同的数据库。对应MySQL中的数据库。
集合:数据库中多个记录的集合。对应MySQL中的表。
文档:数据库中的一条记录。对应MySQL中的行。
字段:数据库中特定记录的值。对应MySQL中的列。

数据类型:

string:字符串。

number:数字。

object:对象。

array:数组。

bool:布尔值。

date:时间。

geo:多种地理位置类型。

null。

云数据库API

触发网络请求的API

API

说明

get

获取集合/记录数据

add

在集合上新增记录

update

更新集合/记录数据

set

替换更新一个记录

remove

删除记录

count

统计查询语句对应的记录条数

获取引用的API

API

说明

database

获取数据库引用,返回Database对象

collection

获取集合引用,返回Collection对象

doc

获取对一个记录的引用,返回Document对象

数据库对象的字段

API

说明

command

获取数据库查询及更新指令,返回Command

serverDate

构造服务端时间

Geo

获取地理位置操作对象,返回Geo对象

集合对象API

API

说明

doc

获取对一个记录的引用,返回Document对象

add

在集合上新增记录

where

构建一个在当前集合上的查询条件,返回Query,查询条件中可使用查询指令

orderBy 

指定查询数据的排序方式

limit

指定返回数据的数量上限

skip

指定查询时从选中的记录列表中的第几项之后开始返回

field

指定返回结果中每条记录应包含的字段

记录/文档对象API

API

说明

get

获取记录数据

update

局部更新数据

set

替换更新记录

remove

删除记录

field

指定返回结果中记录应包含的字段

Command对象查询指令

类别

指令

说明

比较运算

eq

字段是否等于指定值

neq

字段是否不等于指定值

lt

字段是否小于指定值

lte

字段是否小于或等于指定值

gt

字段是否大于指定值

gte

字段是否大于或等于指定值

in

字段值是否在指定数组中

nin

字段值是否不在指定数组中

逻辑运算

and

条件与,表示需同时满足多个查询筛选条件

or

条件或,表示只需满足其中一个条件即可

nor

表示需所有条件都不满足

not

条件非,表示对给定条件取反

字段

exists

字段存在

mod

字段值是否符合给定取模运算

数组

all

数组所有元素是否满足给定条件

elemMatch

数组是否有一个元素满足所有给定条件

size

数组长度是否等于给定值

地理位置

geoNear

找出字段值在给定点的附近的记录

geoWithin

找出字段值在指定区域内的记录

geoIntersects

找出与给定的地理位置图形相交的记录

Command对象更新指令

类别

指令

说明

字段

set

设置字段为指定值

remove

删除字段

inc

原子操作,自增字段值

mul

原子操作,自乘字段值

min

如果字段值小于给定值,则设为给定值

max

如果字段值大于给定值,则设为给定值

rename

字段重命名

数组

push

往数组尾部增加指定值

pop

从数组尾部删除一个元素

shift

从数组头部删除一个元素

unshift

往数组头部增加指定值

addToSet

原子操作,如果不存在给定元素则添加元素

pull

剔除数组中所有满足给定条件的元素

pullAll

剔除数组中所有等于给定值的元素

云数据库操作代码模板:

1. get模板

db.collection('test')
  .where({
    price: _.gt(10)
  })
  .field({
    name: true,
    price: true,
  })
  .orderBy('price', 'desc')
  .skip(1)
  .limit(10)
  .get()

2. aggregate模板

db.collection('test')
  .aggregate()
  .group({
    // 按 category 字段分组
    _id: '$category',
    // 每组有一个 avgSales 字段,其值是组内所有记录的 sales 字段的平均值
    avgSales: $.avg('$sales')
  })
  .end()

3. add模板

db.collection('test')
  .add({
    data: [
      {
        _id: 'apple-1',
        name: 'apple',
        category: 'fruit',
        price: 10,
      },
      {
        _id: 'orange-1',
        name: 'orange',
        category: 'fruit',
        price: 15,
      },
      {
        _id: 'watermelon-1',
        name: 'watermelon',
        category: 'fruit',
        price: 20,
      },
      {
        _id: 'yaourt-1',
        name: 'yaourt',
        category: 'dairy',
        price: 8,
      },
      {
        _id: 'milk-1',
        name: 'milk',
        category: 'dairy',
        price: 12,
      },
      {
        _id: 'chocolate-1',
        name: 'Lindt chocolate',
        category: 'chocolate',
        price: 16,
      },
    ]
  })

3. set模板

db.collection('test').doc('milk-1').set({
  data: {
    name: 'milk',
    category: 'dairy',
    price: 18,
  }
})

4. count模板

db.collection('test')
  .where({
    price: _.gt(10)
  })
  .count()

5. collection.uodate模板

db.collection('test')
  .where({
    category: 'fruit'
  })
  .update({
    data: {
      price: _.inc(5)
    }
  })

6. doc.update模板

db.collection('test').doc('orange-1')
  .update({
    data: {
      price: _.inc(10)
    }
  })

7. remove模板

db.collection('test').doc('milk-1')
  .remove()

8. 变量声明模板

const serverDate = db.serverDate
const { Point } = db.Geo
db.collection('test').doc('milk-2').set({
  data: {
    name: 'milk 2',
    category: 'dairy',
    price: 20,
    updateTime: serverDate(),
    origin: Point(120, 48)
  }
})

9. 正则表达式查询模板

db.collection('table')
  .where({
    collegeName: db.RegExp({
      regexp: 'string',   // 正则表达式
        // i:大小写不敏感  m:跨行匹配 s:让.可以匹配包括换行符在内的所有字符
      options: 'i|m|s', 
    })
  }).get()

10. 多表联查

db.collection('table1')
.aggregate()
.sort({'字段': -1})   //-1:降序  1:升序
.match({
    查询条件
  }).lookup({
      from: 'table2',
      localField: '当前表连接字段',
      foreignField: '对应表外键字段',
      as: '别名'
    }).end()