数据表

数据存储是知晓云提供的核心功能之一,借助它,你可以省去自己搭建数据库,维护数据库及优化数据库查询等麻烦操作。通过以下操作,便可以向在控制台创建的数据表添加一条记录:

  1. let tableName = 'product'
  2. // 通过 `tableName` 实例化一个 `TableObject` 对象,操作该对象即相当于操作对应的数据表
  3. let Product = new BaaS.TableObject(tableName)
  4. // 本地创建一条空记录
  5. let product = Product.create()
  6. let apple = {
  7. name: 'apple',
  8. price: 1,
  9. desc: ['good'],
  10. amount: 0,
  11. created_by: 36395395,
  12. }
  13. // 为上面创建的空记录赋值,并保存到服务器
  14. product.set(apple).save().then(res=>{
  15. console.log(res)
  16. })

返回示例

res 结构如下:

  1. {
  2. "status": 201,
  3. "data": {
  4. "_id": "59a3c2b5afb7766a5ec6e84e",
  5. "amount": 0,
  6. "created_at": 1503904437,
  7. "created_by": 36395395,
  8. "desc": ["good"],
  9. "id": "59a3c2b5afb7766a5ec6e84e",
  10. "name": "apple",
  11. "price": 1.0,
  12. "read_perm": ["user:*"],
  13. "updated_at": 1503904437,
  14. "write_perm": ["user:*"]
  15. }
  16. }

数据表支持多种类型的数据,包括数组类型,时间日期类型,geojson 类型和文件类型,并且支持原子操作等高级功能,如下,既是对产品数量的进行原子性减 1 操作:

  1. let product = Product.getWithoutData(recordID)
  2. // 执行原子性减 1
  3. product.incrementBy('amount', -1)
  4. product.update().then(res => {
  5. console.log(res)
  6. })

返回示例

res 结构如下:

  1. {
  2. "status": 200,
  3. "data": {
  4. "_id": "59a3c2b5afb7766a5ec6e84e",
  5. "amount": -1,
  6. "created_at": 1503904437,
  7. "created_by": 36395395,
  8. "desc": ["good"],
  9. "id": "59a3c2b5afb7766a5ec6e84e",
  10. "name": "apple",
  11. "price": 1.0,
  12. "read_perm": ["user:*"],
  13. "updated_at": 1503904437,
  14. "write_perm": ["user:*"]
  15. }
  16. }

同时,SDK 提供了多种复杂查询操作,包括正则匹配查询,数组查询,甚至是与或的组合查询,如下是正则匹配查询的使用:

使用高级查询我们需要创建一个 BaaS.Query 对象实例,通过在 Query 实例上调用 matchescompare 等方法来设置查询条件,

然后调用 TableObject 实例的 setQuery 方法,来设置查询条件。

最后调用 TableObject 实例的 find 方法,来发起查询。find 方法返回值为一个 Promise。

  1. // 假设 product 表有一个字段为 product_id ,其中数据的格式形如 '112233'
  2. let Product = new BaaS.TableObject('product')
  3. var query = new BaaS.Query()
  4. // 查找产品 ID 以 11 开头,以 33 结尾的产品
  5. regx = /^11\d+33$/
  6. query.matches('product_id', regx)
  7. Product.setQuery(query).find().then(res => {
  8. console.log(res)
  9. })

返回示例

res 结构如下

  1. {
  2. "status": 200,
  3. "data": {
  4. "meta": {
  5. "limit": 20,
  6. "next": null,
  7. "offset": 0,
  8. "previous": null,
  9. "total_count": 2
  10. },
  11. "objects": [
  12. {
  13. "created_at": 1487053098,
  14. "id": "59a3c2b5afb7766a5ec6e84f",
  15. "product_id": "112233"
  16. },
  17. {
  18. "created_at": 1487053095,
  19. "id": "59a3c2b5afb7766a5ec6e84e",
  20. "product_id": "112333"
  21. }
  22. ]
  23. }
  24. }

关于 created_by 字段

如果在云函数中创建数据记录时没有指定 created_by 字段,则创建的记录的 created_by 将是应用所属于企业的超级管理员的用户 ID。此 ID 在控制台 - 用户中将无法被查到(因为并不是小程序 / Web 应用用户)

如果云函数是由小程序所调用,而云函数中需要以小程序用户身份创建记录,可以从 event 中获取到请求云函数用户的信息,从而指定创建记录的 created_by

  1. exports.main = function functionName(event, callback) {
  2. let tableName = 'product'
  3. let Product = new BaaS.TableObject(tableName)
  4. let product = Product.create()
  5. let apple = {
  6. name: 'apple',
  7. created_by: event.request.user.id
  8. }
  9. product.set(apple).save().then(res=>{
  10. callback(null, res.data)
  11. })
  12. }

阅读以下章节,了解更多数据表操作接口: