How do I create an index in Fauna DB that returns sorted data in key value pairs

前端 未结 1 526
庸人自扰
庸人自扰 2021-01-16 18:29

I’m trying to create an index that returns sorted data in an object with keys. The default index for my collection returns something like this:

{
  "ref&         


        
相关标签:
1条回答
  • 2021-01-16 19:28

    the short answer to your question is: "no there is not", but there are probably solutions to your problem (I'll need to better understand the problem you try to solve). Indexes will always return arrays of data since that's how they are structured and FaunaDB provides you access to the raw power of the index. We do not try to be clever and interpret what you might want.

    (Disclaimer, I didn't test the code, it's 11:30 pm here so I'm almost going to log off :) but still wanted to help you)

    That said, there are two options:

    • Instead of basing yourself on the values from your index, take out the ref and write a Map/Get to get the underlying document, that one will come as an object. Each Get though also costs a read so that's a tradeoff to make, it will however be much more flexible when new attributes are added that you don't want to sort on but do want to return (else you'll have to recreate the index).
    Map(
       Paginate(Match(Index('your_index_name'))),
       Lambda(['sort_date', 'title', 'post_type', 'status', 'ref'], Get(Var('ref')))
    )
    
    • Keep the index as is, and once you get these values you can easily write a Map (in FQL) over these index pages and restructure the result by returning an Object. This would look something like
    Map(
       Paginate(Match(Index('your_index_name'))),
       Lambda(['sort_date', 'title', 'post_type', 'status', 'ref'],
         {
           ref: Var('ref'),
           sort_date: Var('sort_date'),
           title: Var('title'),
           post_type: Var('post_type'),
           status: Var('status')
         }
       )
    )
    
    

    That should give you an array of objects instead :)

    0 讨论(0)
提交回复
热议问题