Как сделать запрос (не список) дочерних баз данных по свойствам данных

Есть ли способ запрашивать дочерние базы данных по свойствам данных, то есть по индексу? В сценариях с несколькими арендаторами мы можем получить тонну дочерних баз данных, и было бы здорово иметь возможность запрашивать их, например (дочерние базы данных в этой версии, дочерние базы данных, ожидающие закрытия и т. Д.)

Спасибо

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Я могу сопоставить интересующую меня базу данных. Выбор термина / значения является произвольным и может быть любым, что имеет смысл для вашего приложения.

Другие вопросы по тегам