Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
erosXXX
uni-app
提交
dda9d2d4
U
uni-app
项目概览
erosXXX
/
uni-app
与 Fork 源项目一致
Fork自
DCloud / uni-app
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
dda9d2d4
编写于
10月 28, 2020
作者:
雪洛
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
docs: clientDB联表查询示例优化
上级
f81f991c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
11 deletion
+11
-11
docs/uniCloud/database.md
docs/uniCloud/database.md
+11
-11
未找到文件。
docs/uniCloud/database.md
浏览文件 @
dda9d2d4
...
...
@@ -108,7 +108,7 @@ let res = await db.collection('table').where({
}).
get
()
```
###
jql
查询语法@jsquery
###
JQL
查询语法@jsquery
`jql`
,全称javascript query language,是一种js方式操作数据库的语法规范。
...
...
@@ -291,34 +291,34 @@ book表内有以下数据,title为书名、author为作者:
}
```
order表内有以下数据,book字段为book表的书籍_id,quantity为该订单销售了多少本书:
order表内有以下数据,book
_id
字段为book表的书籍_id,quantity为该订单销售了多少本书:
```
js
{
"
book
"
:
"
1
"
,
"
book
_id
"
:
"
1
"
,
"
quantity
"
:
111
}
{
"
book
"
:
"
2
"
,
"
book
_id
"
:
"
2
"
,
"
quantity
"
:
222
}
{
"
book
"
:
"
3
"
,
"
book
_id
"
:
"
3
"
,
"
quantity
"
:
333
}
{
"
book
"
:
"
4
"
,
"
book
_id
"
:
"
4
"
,
"
quantity
"
:
444
}
{
"
book
"
:
"
3
"
,
"
book
_id
"
:
"
3
"
,
"
quantity
"
:
555
}
```
如果我们要对这2个表联表查询,在订单记录中同时显示书籍名称和作者,那么首先要建立两个表中关联字段
`book`
的映射关系。
即,在order表的db schema中,配置字段 book 的
`foreignKey`
,指向 book 表的 _id 字段,如下
即,在order表的db schema中,配置字段 book
_id
的
`foreignKey`
,指向 book 表的 _id 字段,如下
```
json
//
order表schema
...
...
@@ -329,7 +329,7 @@ order表内有以下数据,book字段为book表的书籍_id,quantity为该
".read"
:
true
},
"properties"
:
{
"book"
:
{
"book
_id
"
:
{
"bsonType"
:
"string"
,
"foreignKey"
:
"book._id"
//
使用foreignKey表示,此字段关联book表的_id。
},
...
...
@@ -366,8 +366,8 @@ schema保存至云端后,即可在前端直接查询。查询表设为order和
// 客户端联表查询
const
db
=
uniCloud
.
database
()
db
.
collection
(
'
order,book
'
)
// 注意collection方法内需要传入所有用到的表名,用逗号分隔,主表需要放在第一位
.
where
(
'
book.title == "三国演义"
'
)
// 查询order表内书名为“三国演义”的订单
.
field
(
'
book{title,author},quantity
'
)
// 这里联表查询book表返回book表内的title、book表内的author、order表内的quantity
.
where
(
'
book
_id
.title == "三国演义"
'
)
// 查询order表内书名为“三国演义”的订单
.
field
(
'
book
_id
{title,author},quantity
'
)
// 这里联表查询book表返回book表内的title、book表内的author、order表内的quantity
.
get
()
.
then
(
res
=>
{
console
.
log
(
res
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录