Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
没有积善却想登上天堂
unidocs-zh
提交
cfb7b031
U
unidocs-zh
项目概览
没有积善却想登上天堂
/
unidocs-zh
与 Fork 源项目一致
Fork自
DCloud / unidocs-zh
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
unidocs-zh
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
cfb7b031
编写于
1月 11, 2022
作者:
DCloud_iOS_WZT
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'master' of gitee.com:dcloud/unidocs-zh
上级
b7d7a8c9
9912d2bc
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
121 addition
and
26 deletion
+121
-26
docs/app-push-fcm.md
docs/app-push-fcm.md
+57
-0
docs/app-statistic-google.md
docs/app-statistic-google.md
+38
-0
docs/uniCloud/jql.md
docs/uniCloud/jql.md
+24
-24
docs/uniCloud/schema.md
docs/uniCloud/schema.md
+2
-2
未找到文件。
docs/app-push-fcm.md
0 → 100644
浏览文件 @
cfb7b031
#### 准备条件
-
可访问Google服务器
注意:中国境内无法访问Google服务器
-
注册Google账号
-
了解什么是
`Firebase Cloud Messaging`
,确定你是否需要用它
+
[
介绍
](
https://firebase.google.com/docs/cloud-messaging
)
+
[
Android设置文档
](
https://firebase.google.com/docs/cloud-messaging/android/client
)
+
[
iOS设置文档
](
https://firebase.google.com/docs/cloud-messaging/ios/client
)
#### 申请开通FCM
1.
打开
[
Firebase引导页
](
https://firebase.google.com
)
2.
创建新项目
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_1.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_2.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_3.jpg
)
3.
创建
`iOS`
平台配置
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_1.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_2.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_3.jpg
)
将
`GoogleService-Info.plist`
下载到本地,HBuilderX中云端打包需要使用此文件
4.
创建
`Android`
平台配置 (如已创建项目,无须创建新项目,直接进行Android平台的配置)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_1.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_2.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_3.jpg
)
项目创建完成后,进入项目配置Android平台的包名、签名证书步骤如下:
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_android_setup_start.png
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_android_setup_package.png
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_android_setup_download_config_file.png
)
将
`google-services.json`
下载到本地,HBuilderX中云端打包需要使用此文件
#### Android平台FCM后台推送消息
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_create_notification_1.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_create_notification_2.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_create_notification_3.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_create_notification_4.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_create_notification_5.jpg
)
#### iOS平台FCM后台推送消息
1.
上传APNS证书
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_ios_upload_profile.jpg
)
2.
网页端实现推送客户端功能
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_create_notification_1.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_create_notification_2.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_create_notification_3.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_create_notification_4.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_create_notification_5.jpg
)
docs/app-statistic-google.md
0 → 100644
浏览文件 @
cfb7b031
#### 准备条件
-
可访问Google服务器
注意:中国境内无法访问Google服务器
-
注册Google账号
-
了解什么是
`Google Analytics`
,确定你是否需要用它
+
[
介绍
](
https://firebase.google.com/docs/analytics
)
+
[
Android设置文档
](
https://firebase.google.com/docs/analytics/get-started?platform=android
)
+
[
iOS设置文档
](
https://firebase.google.com/docs/analytics/get-started?platform=ios
)
#### 申请开通Google统计
1.
打开
[
Firebase引导页
](
https://firebase.google.com
)
2.
创建新项目
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_1.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_2.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_3.jpg
)
3.
创建
`iOS`
平台配置
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_iOS_step_1.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_iOS_step_2.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_iOS_step_3.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_iOS_step_4.jpg
)
将
`GoogleService-Info.plist`
下载到本地,HBuilderX中云端打包需要使用此文件
4.
创建
`Android`
平台配置 (如已创建项目,无须创建新项目,直接进行Android平台的配置)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_1.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_2.jpg
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_project_setup_3.jpg
)
项目创建完成后,进入项目配置Android平台的包名、签名证书步骤如下:
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_android_setup_start.png
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_android_setup_package.png
)
![](
https://native-res.dcloud.net.cn/images/uniapp/push/firebase/firebase_android_setup_download_config_file.png
)
将
`google-services.json`
下载到本地,HBuilderX中云端打包需要配置使用此文件
docs/uniCloud/jql.md
浏览文件 @
cfb7b031
...
...
@@ -366,18 +366,18 @@ const res = await db.collection('goods').where(`${new RegExp(searchVal, 'i')}.te
为方便文档描述定义以下两个概念:
-
临时表:getTemp方法返回的结果,例:
`const article = db.collection('article').getTemp() `
,此处 article 就是一个临时表
-
虚拟表:主表与副表联表产生的表,例:
`db.collection(article, 'comment').get()`
-
虚拟
联
表:主表与副表联表产生的表,例:
`db.collection(article, 'comment').get()`
> JQL于2021年4月28日优化了联表查询策略,详情参考:[联表查询策略调整](https://ask.dcloud.net.cn/article/38966)
`JQL`
提供了更简单的联表查询方案。不需要学习join、lookup等复杂方法。
只需在db schema中,将两个表的关联字段建立映射关系,就可以把2个表当做一个虚拟表来直接查询。
只需在db schema中,将两个表的关联字段建立映射关系,就可以把2个表当做一个虚拟
联
表来直接查询。
JQL联表查询有以下两种写法:
```
js
// 直接关联多个表为虚拟表再进行查询,旧写法,目前更推荐使用getTemp进行联表查询
// 直接关联多个表为虚拟
联
表再进行查询,旧写法,目前更推荐使用getTemp进行联表查询
const
res
=
await
db
.
collection
(
'
order,book
'
).
where
(
'
_id=="1"
'
).
get
()
// 直接关联order和book之后再过滤
// 使用getTemp先过滤处理获取临时表再联表查询,推荐用法
...
...
@@ -387,9 +387,9 @@ const res = await db.collection(order, 'book').get() // 将获取的order表的
上面两种写法最终结果一致,但是第二种写法性能更好。第一种写法会先将所有数据进行关联,如果数据量很大这一步会消耗很多时间。详细示例见下方说明
**关联查询后的虚拟表数据结构如下:**
**关联查询后的虚拟
联
表数据结构如下:**
> 通过HBuilderX提供的[JQL数据库管理](uniCloud/jql-runner.md)功能方便的查看联表查询时的虚拟表结构
> 通过HBuilderX提供的[JQL数据库管理](uniCloud/jql-runner.md)功能方便的查看联表查询时的虚拟
联
表结构
主表某字段foreignKey指向副表时
...
...
@@ -520,7 +520,7 @@ book表的DB Schema也要保持正确
}
```
schema保存后,即使用JQL查询。查询表设为order和book这2个表名后,即可自动按照一个合并虚拟
表来查询,field、where等设置均按合并虚拟
表来设置。
schema保存后,即使用JQL查询。查询表设为order和book这2个表名后,即可自动按照一个合并虚拟
联表来查询,field、where等设置均按合并虚拟联
表来设置。
```
js
// 客户端联表查询
...
...
@@ -631,9 +631,9 @@ db.collection('order')
不止js,
`<unicloud-db>`
组件也支持所有
`jql`
功能,包括联表查询。
在前端页面调试JQL联表查询且不过滤字段时会受权限影响,导致调试比较困难。可以通过HBuilderX提供的
[
JQL数据库管理
](
uniCloud/jql-runner.md
)
功能方便的查看联表查询时的虚拟表结构。
在前端页面调试JQL联表查询且不过滤字段时会受权限影响,导致调试比较困难。可以通过HBuilderX提供的
[
JQL数据库管理
](
uniCloud/jql-runner.md
)
功能方便的查看联表查询时的虚拟
联
表结构。
如上述查询可以直接在
`JQL文件`
中执行以下代码查看完整的虚拟表字段
如上述查询可以直接在
`JQL文件`
中执行以下代码查看完整的虚拟
联
表字段
```
js
db
.
collection
(
'
order,book
'
).
get
()
...
...
@@ -641,7 +641,7 @@ db.collection('order,book').get()
**注意**
-
生成联表查询虚拟
表后关联字段会被替换成被关联表的内容,因此不可在生成虚拟
表后的where内使用关联字段作为条件。举个例子,在上面的示例中,
`where({book_id:"1"})`
是无法筛选出正确结果的,但是可以使用
`where({'book_id._id':"1"})`
-
生成联表查询虚拟
联表后关联字段会被替换成被关联表的内容,因此不可在生成虚拟联
表后的where内使用关联字段作为条件。举个例子,在上面的示例中,
`where({book_id:"1"})`
是无法筛选出正确结果的,但是可以使用
`where({'book_id._id':"1"})`
-
上述示例中如果order表的
`book_id`
字段是数组形式存放多个book_id,也跟上述写法一致,JQL会自动根据字段类型进行联表查询
-
各个表的_id字段会默认带上,即使没有指定返回
...
...
@@ -649,26 +649,26 @@ db.collection('order,book').get()
> 新增于`HBuilderX 3.2.6`
在此之前JQL联表查询只能直接使用虚拟
表,而不能先对主表、副表过滤再生成虚拟表。由于生成虚拟
表时需要整个主表和副表进行联表,在数据量大的情况下性能会很差。
在此之前JQL联表查询只能直接使用虚拟
联表,而不能先对主表、副表过滤再生成虚拟联表。由于生成虚拟联
表时需要整个主表和副表进行联表,在数据量大的情况下性能会很差。
使用临时表进行联表查询,可以先对主表或者副表进行过滤,然后在处理后的临时表的基础上生成虚拟表。
使用临时表进行联表查询,可以先对主表或者副表进行过滤,然后在处理后的临时表的基础上生成虚拟
联
表。
仍以上面article、comment两个表为例
获取article_id为'1'的文章及其评论的数据库操作,在直接联表查询和使用临时表联表查询时写法分别如下
```
js
// 直接使用虚拟表查询
// 直接使用虚拟
联
表查询
const
res
=
await
db
.
collection
(
'
article,comment
'
)
.
where
(
'
article_id._value=="1"
'
)
.
get
()
// 先过滤article表,再获取虚拟表联表获取评论
// 先过滤article表,再获取虚拟
联
表联表获取评论
const
article
=
db
.
collection
(
'
article
'
).
where
(
'
article_id=="1"
'
).
getTemp
()
// 注意是getTemp不是get
const
res
=
await
db
.
collection
(
article
,
'
comment
'
).
get
()
```
直接使用虚拟
表联表查询,在第一步生成虚拟
表时会以主表所有数据和副表进行联表查询,如果主表数据量很大,这一步会浪费相当多的时间。先过滤主表则没有这个问题,过滤之后仅有一条数据和副表进行联表查询。
直接使用虚拟
联表联表查询,在第一步生成虚拟联
表时会以主表所有数据和副表进行联表查询,如果主表数据量很大,这一步会浪费相当多的时间。先过滤主表则没有这个问题,过滤之后仅有一条数据和副表进行联表查询。
**临时表内可以使用如下方法**
...
...
@@ -687,7 +687,7 @@ limit
const
res
=
await
db
.
collection
(
article
,
'
comment
'
).
get
()
```
**组合出来的虚拟表查询时可以使用的方法**
**组合出来的虚拟
联
表查询时可以使用的方法**
> 方法调用必须严格按照顺序,比如foreignKey不能放在where之后
...
...
@@ -700,7 +700,7 @@ skip
limit
```
一般情况下不需要再对虚拟表额外处理,因为数据在临时表内已经进行了过滤排序等操作。以下代码仅供演示,并无实际意义
一般情况下不需要再对虚拟
联
表额外处理,因为数据在临时表内已经进行了过滤排序等操作。以下代码仅供演示,并无实际意义
```
js
const
article
=
db
.
collection
(
'
article
'
).
getTemp
()
...
...
@@ -713,11 +713,11 @@ const res = await db.collection(article, comment).orderBy('title desc').get() //
-
`HBuilderX 3.3.7`
之前 field 内仅可以进行字段过滤,不可对字段重命名、进行运算,
`field('name as value')`
、
`field('add(score1, score2) as totalScore')`
都是不支持的用法
-
`HBuilderX 3.3.7`
及以上版本支持对字段重命名或运算
-
进行联表查询时仅能使用临时表内已经过滤的字段间的关联关系,例如上面article、comment的查询,如果换成以下写法就无法联表查询
-
不建议在虚拟表内再对副表字段重命名或者运算,如果有此类需求应在临时表内进行,会出现预期之外的结果,
**为兼容旧版此用法仅输出警告不会抛出错误**
-
不建议在虚拟
联
表内再对副表字段重命名或者运算,如果有此类需求应在临时表内进行,会出现预期之外的结果,
**为兼容旧版此用法仅输出警告不会抛出错误**
**权限校验**
要求组成虚拟
表的各个临时表都要满足权限限制,即权限校验不会计算组合成虚拟
表之后使用的where、field
要求组成虚拟
联表的各个临时表都要满足权限限制,即权限校验不会计算组合成虚拟联
表之后使用的where、field
以下为一个订单表(order)和书籍表(book)的schema示例
...
...
@@ -776,12 +776,12 @@ const order = db.collection('order')
const
res
=
await
db
.
collection
(
order
,
'
book
'
).
get
()
// 可以通过权限校验
```
如果不对主表过滤,而是对虚拟表(联表结果)进行过滤,则无法满足权限限制(
`order表的"doc.uid==auth.uid"`
)
如果不对主表过滤,而是对虚拟
联
表(联表结果)进行过滤,则无法满足权限限制(
`order表的"doc.uid==auth.uid"`
)
```
js
const
order
=
db
.
collection
(
'
order
'
).
getTemp
()
const
res
=
await
db
.
collection
(
order
,
'
book
'
).
where
(
'
uid==$cloudEnv_uid
'
).
get
()
// 对虚拟表过滤,无法通过权限校验
const
res
=
await
db
.
collection
(
order
,
'
book
'
).
where
(
'
uid==$cloudEnv_uid
'
).
get
()
// 对虚拟
联
表过滤,无法通过权限校验
```
#### 设置字段别名@lookup-field-alias
...
...
@@ -968,17 +968,17 @@ db.collection(comment, user)
**注意**
-
`HBuilderX 3.3.7`
及以上版本支持使用getTemp的虚拟表内使用foreignKey方法
-
`HBuilderX 3.3.7`
及以上版本支持使用getTemp的虚拟
联
表内使用foreignKey方法
#### 副表foreignKey联查@st-foreign-key
`2021年4月28日`
之前的JQL只支持主表的foreignKey,把副表内容嵌入主表的foreignKey字段下面。不支持处理副本的foreignKey。
`2021年4月28日`
调整后,新版支持副表foreignKey联查。副表的数据以数组的方式嵌入到主表中作为一个虚拟表使用。
`2021年4月28日`
调整后,新版支持副表foreignKey联查。副表的数据以数组的方式嵌入到主表中作为一个虚拟
联
表使用。
**关联查询后的数据结构如下:**
> 通过HBuilderX提供的[JQL数据库管理](uniCloud/jql-runner.md)功能方便的查看联表查询时的虚拟表结构
> 通过HBuilderX提供的[JQL数据库管理](uniCloud/jql-runner.md)功能方便的查看联表查询时的虚拟
联
表结构
主表某字段foreignKey指向副表时
...
...
@@ -2951,7 +2951,7 @@ const res = await db.collection('test').aggregate()
-
设定数据操作权限(permission)。什么样的角色可以读/写哪些数据,都在这里配置。
-
设定字段值域能接受的格式(validator),比如不能为空、需符合指定的正则格式。
-
设置数据的默认值(defaultValue/forceDefaultValue),比如服务器当前时间、当前用户id等。
-
设定多个表的字段间映射关系(foreignKey),将多个表按一个虚拟表直接查询,大幅简化联表查询。
-
设定多个表的字段间映射关系(foreignKey),将多个表按一个虚拟
联
表直接查询,大幅简化联表查询。
-
根据schema自动生成表单维护界面,比如新建页面和编辑页面,自动处理校验规则。
这些工具大幅减少了开发者的开发工作量和重复劳动。
...
...
docs/uniCloud/schema.md
浏览文件 @
cfb7b031
...
...
@@ -9,7 +9,7 @@
-
设定字段值域能接受的格式(validator),比如不能为空、需符合指定的正则格式。
-
设定字段之间的约束关系(fieldRules),比如字段结束时间需要晚于字段开始时间。
-
设置数据的默认值(defaultValue/forceDefaultValue),比如服务器当前时间、当前用户id等。
-
设定多个表的字段间映射关系(foreignKey),将多个表按一个虚拟表直接查询,大幅简化联表查询。
-
设定多个表的字段间映射关系(foreignKey),将多个表按一个虚拟
联
表直接查询,大幅简化联表查询。
-
根据schema自动生成前端界面(schema2code),包括列表、详情、新建和编辑页面,自动处理校验规则。
> MongoDB支持通过 [$jsonSchema 操作符](https://docs.mongodb.com/manual/reference/operator/query/jsonSchema/index.html)在插入和更新文档时进行结构验证(非空、类型校验等), $jsonSchema 支持 JSON Schema的草案4,包括[core specification](https://tools.ietf.org/html/draft-zyp-json-schema-04)和[validation specification](https://tools.ietf.org/html/draft-fge-json-schema-validation-00)。uniCloud在MongoDB基础上进行了JSON Schema扩展。
...
...
@@ -114,7 +114,7 @@ properties里的字段列表,每个字段都有很多可以设置的属性,
|errorMessage|string
|
Object |当数据写入或更新时,校验数据合法性失败后,返回的错误提示|
|defaultValue|string
|
Object|默认值|
|forceDefaultValue|string
|
Object|强制默认值,不可通过clientDB的代码修改,常用于存放用户id、时间、客户端ip等固定值。具体参考下表的defaultValue|
|foreignKey|String|关联字段。表示该字段的原始定义指向另一个表的某个字段,值的格式为
`表名.字段名`
,比如订单表的下单用户uid字段指向uni-id-users表的_id字段,那么值为
`uni-id-users._id`
。关联字段定义后可用于
[
联表查询
](
https://uniapp.dcloud.net.cn/uniCloud/clientdb?id=lookup
)
,通过关联字段合成虚拟表,极大的简化了联表查询的复杂度|
|foreignKey|String|关联字段。表示该字段的原始定义指向另一个表的某个字段,值的格式为
`表名.字段名`
,比如订单表的下单用户uid字段指向uni-id-users表的_id字段,那么值为
`uni-id-users._id`
。关联字段定义后可用于
[
联表查询
](
https://uniapp.dcloud.net.cn/uniCloud/clientdb?id=lookup
)
,通过关联字段合成虚拟
联
表,极大的简化了联表查询的复杂度|
|parentKey|String|同一个数据表内父级的字段。详情参考:
[
树状数据查询
](
https://uniapp.dcloud.net.cn/uniCloud/clientdb?id=gettree
)
|
|permission|Object|数据库权限,控制什么角色可以对什么数据进行读/写,可控制表和字段,可设置where条件。见下文
[
详述
](
uniCloud/schema?id=permission
)
|
|label|string|字段标题。schema2code生成前端代码时,渲染表单项前面的label标题|
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录