Как сделать запрос (не список) дочерних баз данных по свойствам данных
Есть ли способ запрашивать дочерние базы данных по свойствам данных, то есть по индексу? В сценариях с несколькими арендаторами мы можем получить тонну дочерних баз данных, и было бы здорово иметь возможность запрашивать их, например (дочерние базы данных в этой версии, дочерние базы данных, ожидающие закрытия и т. Д.)
Спасибо
1 ответ
Как и другие объекты в FaunaDB, базы данных могут быть созданы с произвольными пользовательскими данными, т.е. CreateDatabase({name: "bob", data:{prop: "cool"}})
, Эти данные пользователя также могут быть проиндексированы, как и все остальное. Пример сеанса оболочки:
myDb> Get(Index("by_prop"))
{ ref: Index("by_prop"),
ts: 1560970634960000,
active: true,
partitions: 1,
name: 'by_prop',
source: Databases(),
terms: [ { field: [ 'data', 'prop' ] } ] }
myDb> Get(Database("bob"))
{ ref: Database("bob"),
ts: 1560970374730000,
name: 'bob',
data: { prop: 'cool' } }
myDb> Paginate(Match(Index("by_prop"), "cool"))
{ data: [ Database("bob") ] }
Использование индекса, который имеет термины над data.prop
Я могу сопоставить интересующую меня базу данных. Выбор термина / значения является произвольным и может быть любым, что имеет смысл для вашего приложения.