Con Azure Cosmos DB possiamo memorizzare documenti strutturati in JSON, e non solo, in grande quantità e godere di ottime prestazioni nella loro ricerca. Possiamo estrarre porzioni dei documenti o ricercarli usando molte delle funzioni builtin già disponibili. Delle volte, però, esse non sono sufficienti e necessitiamo di logiche più articolate per estrarre quello che vogliamo. In questo caso possiamo ricorrere alle user-defined function, delle funzioni JavaScript che possiamo definire sul database stesso e con le quali possiamo manipolare il JSON literal.
Per creare la funzione possiamo usare il data explorer direttamente sul portale Azure, il quale sulla toolbar mette a disposizione l'interfaccia apposita.
L'editor che si presenta, lo stesso anche per modificare una funzione già presente, è molto semplice e ci permette di creare una funzione che deve restituire uno dei tipi JavaScript: numeri, stringhe, oggetti e array.
Se usiamo la funzione per ottenere un oggetto complesso o un array, questo verrà incluso nel grafo senza nessuna incompatibilità. Nella figura abbiamo definito una funzione di split di una stringa, la quale quindi restituisce un array.
La funzione può essere poi usata per ottenere un array, come nel seguente esempio:
SELECT udf.SPLIT('chiave1,chiave2',',') AS items
Il risultato sarà il seguente:
[ { "items": [ "chiave1", "chiave2" ] } ]
Possiamo eventualmente usare le JOIN per poter appiattire l'array o combinarlo all'interno di una subquery. Se la funzione viene usata nei filtri, invece, è importante notare che appesantisce notevolmente la ricerca, forzando un scan completo non potendo utilizzare gli indici. Di conseguenza, si può ottimizzare il lavoro aggiungendo altri predicati.
Per maggiori consigli rimandiamo alla documentazione ufficiale:
https://docs.microsoft.com/en-us/azure/cosmos-db/sql-query-udfs
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Applicare un filtro per recuperare alcune issue di GitHub
Testare l'invio dei messaggi con Event Hubs Data Explorer
Utilizzare Azure Cosmos DB con i vettori
Inference di dati strutturati da testo con Semantic Kernel e ASP.NET Core Web API
Gestire gli accessi con Token su Azure Container Registry
Migliorare i tempi di risposta di GPT tramite lo streaming endpoint in ASP.NET Core
Ottimizzare le performance delle collection con le classi FrozenSet e FrozenDictionary
Ottimizzare la latenza in Blazor 8 tramite InteractiveAuto render mode
Migliorare l'organizzazione delle risorse con Azure Policy
Criptare la comunicazione con mTLS in Azure Container Apps
Generare un hash con SHA-3 in .NET
Recuperare App Service cancellati su Azure
I più letti di oggi
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- anche #vs13 update 4 è disponibile in RTM: https://aspit.co/azm
- Indicizzare Cosmos DB con #azure Search https://aspit.co/b4v di @CristianCivera #cosmosdb
- stando a @edbott, la consumer preview di #win8 sarà rilasciata il 29 febbraio! http://aspitalia.com/42