mirror of https://github.com/apache/lucene.git
315 lines
5.9 KiB
Plaintext
315 lines
5.9 KiB
Plaintext
= Variables
|
|
// Licensed to the Apache Software Foundation (ASF) under one
|
|
// or more contributor license agreements. See the NOTICE file
|
|
// distributed with this work for additional information
|
|
// regarding copyright ownership. The ASF licenses this file
|
|
// to you under the Apache License, Version 2.0 (the
|
|
// "License"); you may not use this file except in compliance
|
|
// with the License. You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing,
|
|
// software distributed under the License is distributed on an
|
|
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
// KIND, either express or implied. See the License for the
|
|
// specific language governing permissions and limitations
|
|
// under the License.
|
|
|
|
|
|
== The Let Expression
|
|
|
|
The `let` expression sets variables and returns
|
|
the value of the last variable by default. The output of any streaming expression or math expression can be set to a variable.
|
|
|
|
Below is a simple example setting three variables *`a`*, *`b`*
|
|
and *`c`*. Variables *`a`* and *`b`* are set to arrays. The variable *`c`* is set
|
|
to the output of the `ebeAdd` function which performs element-by-element
|
|
addition of the two arrays.
|
|
|
|
[source,text]
|
|
----
|
|
let(a=array(1, 2, 3),
|
|
b=array(10, 20, 30),
|
|
c=ebeAdd(a, b))
|
|
----
|
|
|
|
In the response, notice that the last variable, *`c`*, is returned:
|
|
|
|
[source,json]
|
|
----
|
|
{
|
|
"result-set": {
|
|
"docs": [
|
|
{
|
|
"c": [
|
|
11,
|
|
22,
|
|
33
|
|
]
|
|
},
|
|
{
|
|
"EOF": true,
|
|
"RESPONSE_TIME": 4
|
|
}
|
|
]
|
|
}
|
|
}
|
|
----
|
|
|
|
== Echoing Variables
|
|
|
|
All variables can be output by setting the `echo` variable to `true`.
|
|
|
|
[source,text]
|
|
----
|
|
let(echo=true,
|
|
a=array(1, 2, 3),
|
|
b=array(10, 20, 30),
|
|
c=ebeAdd(a, b))
|
|
----
|
|
|
|
When this expression is sent to the `/stream` handler it
|
|
responds with:
|
|
|
|
[source,json]
|
|
----
|
|
{
|
|
"result-set": {
|
|
"docs": [
|
|
{
|
|
"a": [
|
|
1,
|
|
2,
|
|
3
|
|
],
|
|
"b": [
|
|
10,
|
|
20,
|
|
30
|
|
],
|
|
"c": [
|
|
11,
|
|
22,
|
|
33
|
|
]
|
|
},
|
|
{
|
|
"EOF": true,
|
|
"RESPONSE_TIME": 0
|
|
}
|
|
]
|
|
}
|
|
}
|
|
----
|
|
|
|
A specific set of variables can be echoed by providing a comma delimited list of variables to the echo parameter.
|
|
Because variables have been provided, the `true` value is assumed.
|
|
|
|
[source,text]
|
|
----
|
|
let(echo="a,b",
|
|
a=array(1, 2, 3),
|
|
b=array(10, 20, 30),
|
|
c=ebeAdd(a, b))
|
|
----
|
|
|
|
When this expression is sent to the `/stream` handler it responds with:
|
|
|
|
[source,json]
|
|
----
|
|
{
|
|
"result-set": {
|
|
"docs": [
|
|
{
|
|
"a": [
|
|
1,
|
|
2,
|
|
3
|
|
],
|
|
"b": [
|
|
10,
|
|
20,
|
|
30
|
|
]
|
|
},
|
|
{
|
|
"EOF": true,
|
|
"RESPONSE_TIME": 0
|
|
}
|
|
]
|
|
}
|
|
}
|
|
----
|
|
|
|
== Caching Variables
|
|
|
|
Variables can be cached in-memory on the Solr node where the math expression
|
|
was run. A cached variable can then be used in future expressions. Any object
|
|
that can be set to a variable, including data structures and mathematical models, can
|
|
be cached in-memory for future use.
|
|
|
|
The `putCache` function adds a variable to the cache.
|
|
|
|
In the example below an array is cached in the `workspace` "workspace1"
|
|
and bound to the `key` "key1". The workspace allows different users to cache
|
|
objects in their own workspace. The `putCache` function returns
|
|
the variable that was added to the cache.
|
|
|
|
[source,text]
|
|
----
|
|
let(a=array(1, 2, 3),
|
|
b=array(10, 20, 30),
|
|
c=ebeAdd(a, b),
|
|
d=putCache(workspace1, key1, c))
|
|
----
|
|
|
|
When this expression is sent to the `/stream` handler it responds with:
|
|
|
|
[source,json]
|
|
----
|
|
{
|
|
"result-set": {
|
|
"docs": [
|
|
{
|
|
"d": [
|
|
11,
|
|
22,
|
|
33
|
|
]
|
|
},
|
|
{
|
|
"EOF": true,
|
|
"RESPONSE_TIME": 11
|
|
}
|
|
]
|
|
}
|
|
}
|
|
----
|
|
|
|
The `getCache` function retrieves an object from the cache by its workspace and key.
|
|
|
|
In the example below the `getCache` function retrieves the array the was cached above and assigns it to variable *`a`*.
|
|
|
|
[source,text]
|
|
----
|
|
let(a=getCache(workspace1, key1))
|
|
----
|
|
|
|
When this expression is sent to the `/stream` handler it responds with:
|
|
|
|
[source,json]
|
|
----
|
|
{
|
|
"result-set": {
|
|
"docs": [
|
|
{
|
|
"a": [
|
|
11,
|
|
22,
|
|
33
|
|
]
|
|
},
|
|
{
|
|
"EOF": true,
|
|
"RESPONSE_TIME": 11
|
|
}
|
|
]
|
|
}
|
|
}
|
|
----
|
|
|
|
The `listCache` function can be used to list the workspaces or the keys in a specific workspace.
|
|
|
|
In the example below `listCache` returns all the workspaces in the cache as an array of strings.
|
|
|
|
[source,text]
|
|
----
|
|
let(a=listCache())
|
|
----
|
|
|
|
When this expression is sent to the `/stream` handler it
|
|
responds with:
|
|
|
|
[source,json]
|
|
----
|
|
{
|
|
"result-set": {
|
|
"docs": [
|
|
{
|
|
"a": [
|
|
"workspace1"
|
|
]
|
|
},
|
|
{
|
|
"EOF": true,
|
|
"RESPONSE_TIME": 0
|
|
}
|
|
]
|
|
}
|
|
}
|
|
----
|
|
|
|
|
|
In the example below all the keys in a specific workspace are listed:
|
|
|
|
[source,text]
|
|
----
|
|
let(a=listCache(workspace1))
|
|
----
|
|
|
|
When this expression is sent to the `/stream` handler it responds with:
|
|
|
|
[source,json]
|
|
----
|
|
{
|
|
"result-set": {
|
|
"docs": [
|
|
{
|
|
"a": [
|
|
"key1"
|
|
]
|
|
},
|
|
{
|
|
"EOF": true,
|
|
"RESPONSE_TIME": 0
|
|
}
|
|
]
|
|
}
|
|
}
|
|
----
|
|
|
|
The `removeCache` function can be used to remove a a key from a specific
|
|
workspace. This `removeCache` function removes the key from the cache
|
|
and returns the object that was removed.
|
|
|
|
In the example below the array that was cached above is removed from the cache.
|
|
|
|
[source,text]
|
|
----
|
|
let(a=removeCache(workspace1, key1))
|
|
----
|
|
|
|
When this expression is sent to the `/stream` handler it responds with:
|
|
|
|
[source,json]
|
|
----
|
|
{
|
|
"result-set": {
|
|
"docs": [
|
|
{
|
|
"a": [
|
|
11,
|
|
22,
|
|
33
|
|
]
|
|
},
|
|
{
|
|
"EOF": true,
|
|
"RESPONSE_TIME": 0
|
|
}
|
|
]
|
|
}
|
|
}
|
|
----
|