数据表
数据存储是知晓云提供的核心功能之一,借助它,你可以省去自己搭建数据库,维护数据库及优化数据库查询等麻烦操作。通过以下操作,便可以向在控制台创建的数据表添加一条记录:
let tableName = 'product'
// 通过 `tableName` 实例化一个 `TableObject` 对象,操作该对象即相当于操作对应的数据表
let Product = new BaaS.TableObject(tableName)
// 本地创建一条空记录
let product = Product.create()
let apple = {
name: 'apple',
price: 1,
desc: ['good'],
amount: 0,
created_by: 36395395,
}
// 为上面创建的空记录赋值,并保存到服务器
product.set(apple).save().then(res=>{
console.log(res)
})返回示例
res 结构如下:
数据表支持多种类型的数据,包括数组类型,时间日期类型,geojson 类型和文件类型,并且支持原子操作等高级功能,如下,既是对产品数量的进行原子性减 1 操作:
返回示例
res 结构如下:
同时,SDK 提供了多种复杂查询操作,包括正则匹配查询,数组查询,甚至是与或的组合查询,如下是正则匹配查询的使用:
使用高级查询我们需要创建一个 BaaS.Query 对象实例,通过在 Query 实例上调用 matches、compare 等方法来设置查询条件,
然后调用 TableObject 实例的 setQuery 方法,来设置查询条件。
最后调用 TableObject 实例的 find 方法,来发起查询。find 方法返回值为一个 Promise。
返回示例
res 结构如下
关于 created_by 字段
created_by 字段如果在云函数中创建数据记录时没有指定 created_by 字段,则创建的记录的 created_by 将是应用所属于企业的超级管理员的用户 ID。 此 ID 在控制台 - 用户中将无法被查到(因为并不是小程序 / Web 应用用户)
如果云函数是由小程序所调用,而云函数中需要以小程序用户身份创建记录,可以从 event 中获取到请求云函数用户的信息,从而指定创建记录的 created_by:
阅读以下章节,了解更多数据表操作接口:
Last updated
Was this helpful?