一、操作云数据库的方式
1、 云函数通过传统方式操作数据库
注意1:
这里和微信云开发非常不一样,如果是微信云开发,则不涉及JQL的相关知识的语法,在客户端也可通过传统方式操作数据库。
注意2:
wx小程序云函数--单击右键上传云函数
unicloud云函数都是本地的,即写即看,右键上传所有的云函数
2、 客户端通过JQL语法操作数据库
注意1:权限设置
图1.1 未设置权限的报错信息
注意2:JQL语法不支持一些操作符(比如数组类型数据的push和pop)
图1.2 注意2在官方文档的相关说明
图1.3 注意2的相关报错信息
3、 云对象操作数据库
一、创建云对象
通过云对象方式实现原子自增/自减的更新指令。
const db = uniCloud.database()
const dbCmd = db.command
module.exports = {
_before: function () { // 通用预处理器
},
/**
* 原子自增自减
* @param {Object} tabName 表名
* @param {Object} attr 属性
* @param {Object} id id
* @param {Object} num 1自增 -1自减
*/
//
async operation(tabName,attr,id,num) {
let obj = {}
obj[attr] = dbCmd.inc(num)
return await db.collection(tabName).doc(id).update(obj)
}
}
- 学到的新知识点---自动生成参数说明表列---(/**回车)
- 学到的新知识点---待更新数据库字段为变量
async operation(tabName,attr,id,num) {
//这里的attr为变量,无法直接书写,于是采用上面的方式进行修改
return await db.collection(tabName).doc(id).update({
attr : dbCmd.inc(num)
})
}
二、页面引入云对象
const utils = uniCloud.importObject('utilsObj',{
customUI:true //取消自动显示交互界面
})
三、调用使用
utils.operation('community-post','view_count',this.commentId,1).then(res=>{
console.log(res)
})
4、 unicloud-db前端组件操作数据库(get)
二、小程序间的跳转需求
uni.navigateToMiniProgram({
appId: 'wxe3f67a104045c220', //被跳转的appId
path: 'pages/goods-datails/goods-datails', //要跳转的目标小程序(B小程序)的路径
extraData: { //需要传递给目标小程序的参数
'userId': '1',
'token': 'IBvb1ryE&goodsId=144419',
'goodsId': '144419',
'type': '19'
},
envVersion: 'release', //跳转的版本:develop(开发版),trial(体验版),release(正式版)
success(res) {
// 打开成功
console.log("dwadw",res)
},
fail(res) {
// 打开失败
console.log(res)
}
})
参数说明:
1、appId:要跳转的目标小程序的appId---wxe3f67a104045c220---三创赛小程序appId。
2、path要打开的小程序的页面的相对路径。
3、extraData需要传递给目标小程序的数据。