-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Expressions
Expressions are path or formulas to access and modify your document data. Based on JSON path article (http://goessner.net/articles/JsonPath/), LiteDB support a near syntax to navigate in a single document. Path always returns an IEnumerable<BsonValue>
in any case.
BsonExpression
are the class that parse a string expression (or path) and compile into a LINQ Expression to be fast evaluate by LiteDB. Parser uses
- Path starts with
$
:$.Address.Street
- Int values starts with
[0-9]*
:123
- Double values starts with
[0-9].[0-9]
:123.45
- Strings are represented with a single quote
'
:'Hello World'
- Null are just
null
- Bool are represented using
true
orfalse
keyword. - Document starts with
{ key1: <value|expression>, key2: ... }
- Arrays are represented with
[values, expressions, paths, ...]
- Functions are represented with
FUNCTION_NAME(par1, par2, ...)
:LOWER($.Name)
Examples:
$.Price
$.Price + 100
SUM($.Items[*].Price)
var expr = new BsonExpression("SUM($.Items[*].Unity * $.Items[*].Price)");
var total = expr.Execute(doc, true).First().AsDecimal;
Expressions also can be used in:
- Create an index based on an expression:
collection.EnsureIndex("Name", true, "LOWER($.Name)")
collection.EnsureIndex(x => x.Name, true, "LOWER($.Name)")
- Query documents inside a collection based on expression (full scan search)
Query.EQ("SUBSTRING($.Name, 0, 1)", "T")
- Update shell command
db.customers.update $.Name = LOWER($.Name) where _id = 1
- Create new document result in SELECT shell command
db.customers.select { upper_titles: ARRAY(UPPER($.Books[*].Title)) } where $.Name startswith "John"
-
$
- Root -
$.Name
- Name field -
$.Name.First
- First field from a Name subdocument -
$.Books
- Returns book array value -
$.Books[0]
- Return first book inside books array -
$.Books[*]
- Return all books inside books array -
$.Books[*].Title
Return titles from all books -
$.Books[-1]
- Return last book inside books array
Path also support expression to filter child node
-
$.Books[@.Title = 'John Doe']
- Return all books where title is John Doe -
$.Books[@.Price > 100].Title
- Return all titles where book price are greater than 100
Inside array, @
represent current sub document. It's possible use functions inside expressions too:
-
$.Books[SUBSTRING(LOWER(@.Title), 0, 1) = 'j']
- Return all books with title starts with T or t.
Functions are always works in IEnumerable<BsonValue>
as input/output parameters.
-
LOWER($.Name)
- ReturnsIEnumerable
with a single element -
LOWER($.Books[*].Title)
- ReturnsIEnumerable
with all values in lower case
Operators are function to implement same math syntax. Support
-
ADD(<left>, <right>)
:<left> + <right>
(If any side are string, concat values and return as string.) -
MINUS(<left>, <right>)
:<left> - <right>
-
MULTIPLY(<left>, <right>)
:<left> * <right>
-
DIVIDE(<left>, <right>)
:<left> / <right>
-
MOD(<left>, <right>)
:<left> % <right>
-
EQ(<left>, <right>)
:<left> = <right>
-
NEQ(<left>, <right>)
:<left> != <right>
-
GT(<left>, <right>)
:<left> > <right>
-
GTE(<left>, <right>)
:<left> >= <right>
-
LT(<left>, <right>)
:<left> < <right>
-
LTE(<left>, <right>)
:<left> <= <right>
-
AND(<left>, <right>)
:<left> && <right>
(Left and right must be a boolean) -
OR(<left>, <right>)
:<left> || <right>
: Left and right must be a boolean) -
IIF(<condition>, <ifTrue>, <ifFalse>)
: (Condition must be a boolean value)
-
db.dummy.select ((2 + 11 % 7)-2)/3
=>1.33333
-
db.dummy.select 'My Id is ' + $._id
=>"My Id is 1"
-
db.customers.select { info: IIF($._id < 20, 'Less', 'Greater') + ' than twenty' }
- =>
{ info: "Less than twenty" }
- =>
String function will work only if your <values>
are string. Any other data type will skip results
Function | Description |
---|---|
LOWER(<values>) |
Same ToLower() from String . Returns a string |
UPPER(<values>) |
Same ToUpper() from String . Returns a string |
SUBSTRING(<values>, <index>, <length>) |
Same Substring() from String . Returns a string |
LPAD(<values>, <totalWidth>, <paddingChar>) |
Same PadLeft() from String . Returns a string |
RPAD(<values>, <totalWidth>, <paddingChar>) |
Same PadRight() from String . Returns a string |
FORMAT(<values>, <format>) |
Same Format() from String . Works if any data type (use RawValue ). Returns a string |
Function | Description |
---|---|
SUM(<values>) |
Sum all number values and returns a number |
COUNT(<values>) |
Count all values and returns a integer |
MIN(<values>) |
Get min value in value list |
MAX(<values>) |
Get max value in value list |
AVG(<values>) |
Calculate average in list of values |
FIRST(<values>) |
Get first value from list of values |
LAST(<values>) |
Get last value from list of values |
All aggregates functions works in a single document and always with an IEnumerable selector of an array: (SUM($.Items[*].Price)
)
Function | Description |
---|---|
ARRAY(<values>) |
Convert all values into a single array |
IS_MINVALUE(<values>) |
Return true for each value that are minvalue |
IS_NULL(<values>) |
Return true for each value that are null |
IS_INT32(<values>) or IS_INT(<values>)
|
Return true for each value that are int |
IS_INT64(<values>) or IS_LONG(<values>)
|
Return true for each value that are long |
IS_DOUBLE(<values>) |
Return true for each value that are double |
IS_DECIMAL(<values>) |
Return true for each value that are decimal |
IS_NUMBER(<values>) |
Return true for each value that are number |
IS_STRING(<values>) |
Return true for each value that are string |
IS_ARRAY(<values>) |
Return true for each value that are array |
IS_BINARY(<values>) |
Return true for each value that are binary |
IS_OBJECTID(<values>) |
Return true for each value that are objectid |
IS_GUID(<values>) |
Return true for each value that are guid |
IS_BOOLEAN(<values>) or IS_BOOL(<values>)
|
Return true for each value that are boolean |
IS_DATETIME(<values>) or IS_DATE(<values>)
|
Return true for each value that are datetime |
IS_MAXVALUE(<values>) |
Return true for each value that are maxvalue |
MINVALUE() |
Return new min value |
MAXVALUE() |
Return new max value |
INT32(<values>) or INT(<values>)
|
Convert all possible values into int |
INT64(<values>) or LONG(<values>)
|
Convert all possible values into long |
DOUBLE(<values>) |
Convert all possible values into double |
DECIMAL(<values>) |
Convert all possible values into decimal |
STRING(<values>) |
Convert each value as string |
OBJECTID() |
Return new objectid |
OBJECTID(<values>) |
Convert all possible values (string) into objectid |
GUID() |
Return new guid |
GUID(<values>) |
Convert all possible values (string) into guid |
DATETIME() or DATE()
|
Return new date (now) |
DATETIME(<values>) or DATE(<values>)
|
Convert all possible values (string) into datetime |
DATETIME(<year>, <month>, <day>) or DATE(<year>, <month>, <day>)
|
Create new date based on year, month, day (int) passed |
Function | Description |
---|---|
YEAR(<date>) |
Return year (as int) from date |
MONTH(<date>) |
Return month(as int) from date |
DAY(<date>) |
Return day (as int) from date |
HOUR(<date>) |
Return hour (as int) from date |
MINUTE(<date>) |
Return minute (as int) from date |
SECOND(<date>) |
Return second (as int) from date |
DATEADD(<datePart>, <number>, <date>) |
Return new date adding internal from date |
DATEDIFF(<datePart>, <dateStart>, <dateEnd>) |
Return interval between start and end date |
Date parts are strings used in DATEADD
and DATEDIFF
-
y
oryear
= Year -
M
ormonth
= Month -
d
orday
= Day -
h
orhour
= Hour -
m
orminute
= Minute -
s
orsecond
= Second
db.orders.select { in_days: DATEDIFF('day', $.DueDate, DATE()) }
Function | Description |
---|---|
EXTEND(<src>, <extend>) |
Copy, into source document, all field from extend document EXTEND({a:1}, {b:2}) = {a:1, b:2}
|
JSON(<strings>) |
Deserialize string value into a BsonDocument value. JSON('{a:1}') = {a:1}
|
KEYS(<docs>) |
Returns all keys from all documents. KEYS({a:1, b:2}) = a , b
|
All function are static methods from BsonExpression
.
Data Modeling
- Data Structure
- BsonDocument
- Object Mapping
- Relationships with Document References
- Collections
- FileStorage
Index
Query
Database
Version 4 changes
Shell