To send query to database, we need to create query which consists of 4 main parts:
The created query won't send anything to database until run()is called.
For example, to query notes which have datetime start from year 2020.
import shelfquery
notes = shelfquery\
    .db()\
    .shelf('note')\
    .filter(lambda note: note['datetime'] >= datetime.fromisoformat('2020-01-01'))\
    .run()
Let's start with database selection using code below.
db = shelfquery.db(host='127.0.0.1', port=17000)
This will create DB instance which contains information of database IP adress and port.
Next, we can select shelf in database and we're ready to use Chained Query APIs.
note_shelf = db.shelf('note')
dbin this section is a variable which keep DB instance.
count() -> number: intCount entries
count = db.shelf('note').count()
delete() -> NoneDelete entries
edit(func(entry) -> entry: dict) -> NoneEdit entries using function.
def add_like(note)  # Get an entry as the argument.
    note['like'] += 1  # Add 1 like
    return note  # Return the entry to save in database.
db.shelf('note')\
    .get('7742df1c-a27f-11ea-8c6a-04d3b02081c2')\
    .edit(add_like)\
    .run()
filter(func(entry) -> bool) -> entriesFilter entries using function/lambda.
notes = db.shelf('note')\
    .filter(lambda note: 'some words' in note['title'])\
    .run()
first(func(entry) -> bool) -> entryGet the first entry matched by function/lambda.
note = db.shelf('note')\
    .first(lambda note: 'some words' in note['title'])\
    .run()
get(id: 'UUID1 String') -> entryGet the entry at UUID1 hash key in database.
note = db.shelf('note')\
    .get('6c286bcc-a2a9-11ea-8eff-04d3b02081c2')\
    .run()
add(entry: dict) -> uuid1: strInsert an entry at generated UUID1 hash key in database.
Return UUID1 hash of the inserted entry.
note_uuid1 = db.shelf('note')\
    .insert({'title': 'Shelf DB', 'content': 'Test'})\
    .run()
map(func(entry) -> Any) -> IteratorMapping function to entries (See python
map())
Return value from provided function will be kept in chained query's result
as iterator.
# Get all note titles.
note_titles = db.shelf('note').map(lambda note: note['title']).run()
# Get user without password.
def user_without_password(user):
    del user['password']
    return user
users = db.shelf('user').map(user_without_password).run()
patch(uuid1: str, data: dict)Patch an entry at provided UUID1 hash in database. Create one if not exists.
put(uuid1: str, entry: dict)Put an entry at provided UUID1 hash in database. It will replace any existing entry if any.
db.shelf('note')\
    .put(
        '6c286bcc-a2a9-11ea-8eff-04d3b02081c2',
        {'title': 'Shelf DB', 'content': 'Test'})\
    .run()
reduce(func(accumulator, current_value, initializer=None) -> accumulator)Apply reduce function. (See reduce())
Can be use with map function. (See MapReduce)
# Get total size of all photos in the shelf.
total_size = db.shelf('photo')\
    .map(lambda photo: photo['size'])\
    .reduce(lambda total, current: total + current)
    .run()
replace(data: dict)Replace data to an entry/entries in chained query's result.
slice(start: int, stop: int, step=1)Slice chained query's result.
# Sort notes by datetime and get notes at index [20:40]
notes = db.shelf('note')\
    .sort(key=lambda note: note['datetime'])\
    .slice(20,40)\
    .run()
sort(key=lambda entry: entry.timestamp, reverse=False)Sort entries. See sort
# Sort then slice [0:50]
notes = db.shelf('note')\
    .sort(key=lambda note: note['datetime'])\
    .slice(0,50)\
    .run()
update(patch: dict)Update patch to an entry/entries in chained query's result.
db.shelf('note').update({'publish': False}).run()
run()Send chained query to database.