Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
genary
uni-app
提交
286f2854
U
uni-app
项目概览
genary
/
uni-app
与 Fork 源项目一致
Fork自
DCloud / uni-app
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
286f2854
编写于
7月 06, 2021
作者:
雪洛
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
docs: unicloud database multi send
上级
b318d6c8
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
85 addition
and
0 deletion
+85
-0
docs/uniCloud/clientdb.md
docs/uniCloud/clientdb.md
+85
-0
未找到文件。
docs/uniCloud/clientdb.md
浏览文件 @
286f2854
...
...
@@ -2387,6 +2387,91 @@ const res = await db.collection('score')
-
distinct指对返回结果中完全相同的记录进行去重,重复的记录只保留一条。因为
`_id`
字段是必然不同的,所以使用distinct时必须同时指定field,且field中不可存在
`_id`
字段
### 同时发送多条数据库请求@multi-send
在实际业务中通常会遇到一个页面需要查询多次的情况,比如应用首页需要查询轮播图列表、公告列表、首页商品列表等。如果分开请求需要发送很多次网络请求,这样会影响性能。使用multiSend可以将多个数据库请求合并成一个发送。
**用法**
```
js
const
bannerQuery
=
db
.
collection
(
'
banner
'
).
field
(
'
url,image
'
).
getTemp
()
// 这里使用getTemp不直接发送get请求,等到multiSend时再发送
const
noticeQuery
=
db
.
collection
(
'
notice
'
).
field
(
'
text,url,level
'
).
getTemp
()
const
res
=
await
db
.
multiSend
(
bannerQuery
,
noticeQuery
)
```
**返回值**
```
js
// 上述请求返回以下结构
res
=
{
code
:
0
,
// 请求整体执行错误码,注意如果多条查询执行失败,这里的code依然是0,只有出现网络错误等问题时这里才会出现错误
message
:
''
,
// 错误信息
dataList
:
[{
code
:
0
,
// bannerQuery 对应的错误码
message
:
''
,
// bannerQuery 对应的错误信息
data
:
[]
// bannerQuery 查询到的数据
},
{
code
:
0
,
// noticeQuery 对应的错误码
message
:
''
,
// noticeQuery 对应的错误信息
data
:
[]
// noticeQuery 查询到的数据
}]
}
```
unicloud-db组件也支持使用getTemp方法,结合multiSend可以与其他数据库请求一起发送
用法示例:
```
html
<template>
<view>
<!-- 设置unicloud-db 组件为手动加载 loadtime="manual" -->
<unicloud-db
collection=
"banner"
loadtime=
"manual"
ref=
"udb"
v-slot:default=
"{data, error}"
>
<view
v-if=
"error"
>
{{error.message}}
</view>
<view
v-else
>
<view
v-for=
"(item,index) in data"
:key=
"index"
>
<image
:src=
"item.url"
></image>
</view>
</view>
</unicloud-db>
<button
type=
"default"
@
click=
"test"
>
test
</button>
</view>
</template>
<script>
export
default
{
data
()
{
return
{
title
:
'
Hello
'
}
},
onLoad
()
{
},
methods
:
{
test
()
{
const
db
=
uniCloud
.
database
()
const
bannerQuery
=
this
.
$refs
.
udb
.
getTemp
()
// 调用模板内unicloud-db组件实例的getTemp方法
const
noticeQuery
=
db
.
collection
(
'
notice
'
).
getTemp
()
db
.
multiSend
(
bannerQuery
,
noticeQuery
)
.
then
(
res
=>
{
console
.
log
(
'
banner
'
,
res
.
result
.
dataList
[
0
]);
// 使用unicloud-db组件的getTemp请求无需额外处理,查询结果会直接被设置到unicloud-db组件内
console
.
log
(
'
notice
'
,
res
.
result
.
dataList
[
1
]);
// 不使用unicloud-db组件的getTemp请求需要自行处理返回值
})
.
catch
(
err
=>
{
console
.
error
(
err
)
})
// uniCloud.database().collection('test').get()
}
}
}
</script>
<style>
</style>
```
### 新增数据记录add
> 代码块`dbadd`
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录