此函数的 EBNF 语法如下所示
SearchConditionStr
::= '"' Expression '"'
此函数的 EBNF 语法如下所示
SearchExprStrList
::= '[' '"' Expression '"' ( ',' '"' Expression '"' )* ']'
此函数的 EBNF 语法如下所示
ProjectedDocumentExprStr
::= ProjectedSearchExprStrList | 'expr("' JSONDocumentExpression '")'
此函数的 EBNF 语法如下所示
ProjectedSearchExprStrList
::= '[' '"' Expression ( 'AS' Alias )? '"' ( ',' '"' Expression ( 'AS' Alias )? '"' )* ']'
此函数的 EBNF 语法如下所示
SortExprStrList
::= '[' '"' Expression ( 'ASC' | 'DESC' )? '"' ( ',' '"' Expression ( 'ASC' | 'DESC' )? '"' )* ']'
此函数的 EBNF 语法如下所示
ExprOrLiteral
::= 'expr("' Expression '")' | Literal
此函数的 EBNF 语法如下所示
ExprOrLiterals
::= ExprOrLiteral ( ',' ExprOrLiteral )*
此函数的 EBNF 语法如下所示
ExprOrLiteralOrOperand
::= ExprOrLiteral
此函数的 EBNF 语法如下所示
PlaceholderValues
::= '{' PlaceholderName ':' ( ExprOrLiteral ) '}'
此函数的 EBNF 语法如下所示
PlaceholderName
::= NamedPlaceholderNotQuestionmarkNotNumbered
此函数的 EBNF 语法如下所示
DocPath
::= ( '[*]' | ( '[' Index ']' ) | '.*' | ( '.' StringLiteral ) | '**' )+
此函数的 EBNF 语法如下所示
Literal
::= '"' StringLiteral '"' | Number | true | false | Document
Expression
::= Literal
| DocPath
| TableField
| FunctionName '(' Expression ( ',' Expression )* ')'
| ':' PlaceholderName
| Expression Operator Expression
| JSONExpression
需要 JSON 文档的 API 调用允许使用多种数据类型来描述文档。根据 X DevAPI 实现和语言,可以使用以下任何数据类型
字符串
原生 JSON
等效的 JSON 语法
DbDoc
生成的文档类
所有 X DevAPI 实现都允许使用特殊的 DbDoc 类型和字符串来表示文档。
此函数的 EBNF 语法如下所示
Document
::= JSONDocument | JSONEquivalentDocument | DbDoc | GeneratedDocumentClasses
此函数的 EBNF 语法如下所示
JSONExpression
::= JSONDocumentExpression | '[' Expression ( ',' Expression )* ']'
此函数的 EBNF 语法如下所示
JSONDocumentExpression
::= '{' StringLiteral ':' JSONExpression (',' StringLiteral ':' JSONExpression)* '}'
此函数的 EBNF 语法如下所示
FunctionName
::= StringLiteral | StringLiteral '.' StringLiteral
此函数的 EBNF 语法如下所示
DocumentOrJSON
::= Document | 'expr("' JSONDocumentExpression '")'
此函数的 EBNF 语法如下所示
TableField
::= ( StringLiteral '.' )? ( StringLiteral '.' )? StringLiteral ( '@' DocPath )?