查询数据项
数据类型对应查询操作符表
string
=, in, notIn, !=, isNull, isNotNull, contains, matches, exists, notExists
integer
=, >, >=, <, <=, !=, in, notIn, isNull, isNotNull, exists, notExists
number
=, >, >=, <, <=, !=, in, notIn, isNull, isNotNull, exists, notExists
array
=, in, notIn, isNull, isNotNull, arrayContains, exists, notExists
file、geojson、object、date 类型的 array 不支持查询操作。如果进行查询,会返回空数组
boolean
=, exists, notExists, isNull, isNotNull
date
=, >, >=, <, <=, exists, notExists, isNull, isNotNull
file
isNull, isNotNull, exists, notExists
geojson
include, within, withinCircle, exists, notExists, isNull, isNotNull
object
=, hasKey, isNull, isNotNull, exists, notExists
pointer
=, in, notIn, !=, isNull, isNotNull, exists, notExists
info
使用查询时,字段必须满足相应的类型。(请先查阅上表)
file、geojson、object、date 类型的 array 不支持查询操作。如果进行查询,会返回空数组
操作步骤
1.通过 tableName 或 tableId 实例化一个 Table 对象,操作该对象即相当于操作对应的数据表,这里推荐用 tableName
示例代码
参数说明
tableName 和 tableID 二选一
tableId
String
数据表的 Id
tableName
String
数据表名
2.创建 Where 对象,在该对象上添加查询条件
查看下面的文档,了解目前支持的查询条件
3.设置查询条件并执行查找操作
参数说明
query
Query
N
查询条件
返回结果
info 注意:知晓云的 api URL 长度限定为 16386,超出则返回 502,请在构造查询条件时注意长度控制,如 in 操作符后边的数组长度、match 操作符后边的字符串长度等。
示例
示例代码
比较查询
operator 说明:
equalTo
=
notEqualTo
!=
greaterThan
>
greaterThanOrEqualTo
>=
lessThan
<
lessThanOrEqualTo
<=
operator 说明:
BaaSOperatorEqualTo
=
BaaSOperatorNotEqualTo
!=
BaaSOperatorGreaterThan
>
BaaSOperatorGreaterThanOrEqualTo
>=
BaaSOperatorLessThan
<
BaaSOperatorLessThanOrEqualTo
<=
字符串查询
查询返回满足包含相应字符串的记录,如下示例:
正则匹配
构造正则表达式语法
pattern: 匹配模式
flags: 修饰符,如下表介绍
g
global match; find all matches rather than stopping after the first match
i
ignore case; if u flag is also enabled, use Unicode case folding
m
multiline; treat beginning and end characters (^ and $) as working over multiple lines (i.e., match the beginning or end of each line (delimited by \n or \r), not only the very beginning or end of the whole input string)
s
"dotAll"; allows . to match newlines
u
Unicode; treat pattern as a sequence of Unicode code points
z
sticky; matches only from the index indicated by the lastIndex property of this regular expression in the target string (and does not attempt to match from any later indexes).
info 正则表达式,使用的是
JavaScript的语法规则,请参考 RegExp。
代码示例
数组查询
inList
数据表中的 field 的类型不限制,field 的 value 含有 array 中的一个或多个
notInList
数据表中的 field 的类型不限制,field 的 value 不含有 array 中的任何一个
arrayContains
数据表中的 field 的类型必须为数组, field 的 value 包含 array 中的每一个
如果希望查找数组中只包含指定数组中所有的值的记录,可以使用比较查询
null 或非 null 查询
查询字段值为 null 或非 null 记录
空或非空查询
查询字段值为空或非空记录
hasKey 查询 (仅限 object 类型)
参数说明
key
String
是
在数据表中的类型必须是 Object
value
String
是
需要检测的属性名, 只能包含字母、数字和下划线,必须以字母开头
示例代码
假设数据表有如下数据行
查询字段 publisherInfo 中存在 location 属性的数据行
info 目前暂不支持查询内嵌属性
假设数据行如下
则下面的查询语句是非法的
pointer 查询
info 目前 pointer 仅支持针对 pointer 本身的查询,不支持嵌套查询(即查询 pointer 指向的数据行的字段)
示例代码
假设现在有两张表: Book 表和 Author 表。
order 表部分字段结构如下:
author
pointer
指向了 Author 表
现在需要查询 Book 表中,同时满足以下条件的数据行:
author 字段指向 Author 表中 id 为
5bad87ab0769797b4fb27a1b的数据行
组合查询
当有多个查询时,可以使用 and 和 or 来组合查询查询条件。
Last updated
Was this helpful?