Azure DocumentDB è il database documentale che permette di memorizzare in formato JSON documenti, manipolarli e fare ricerche su di esso. Si tratta di un servizio completamente gestito e scalabile. Quando memorizziamo un documento ci sono alcuni campi speciali che accompagnano il documento stesso, come il _ts per indicare la data di ultima modifica del documento, id per identificare il documento e _etag per gestire i conflitti.
Recentemente è stato aggiunto un nuovo campo, di nome ttl, che ci permette di specificare per quanti secondi il documento è valido. Questo significa che il documento viene eliminato automaticamente decorso il tempo specificato dall'ultima modifica. Il vantaggio, rispetto ad un'esplicita operazione di DELETE, è che non viene coinvolto nessuna Resource Unit (RU) e non influenza le prestazioni del database. Il documento infatti, quando scade, viene marcato come scaduto, tolto dalle quota di utilizzo, ed eliminato nel momento più opportuno.
Per usufruire di questa funzionalità dobbiamo prima di tutto abilitarne il supporto a livello di collezione. Questo è possibile a livello di API o dal portale, come nella figura.

Possiamo impostare un TTL a livello di collezione, ed eventualmente sovrascriverlo ad ogni specifico documento, oppure abilitarne il supporto e impostare il TTL ad ogni documento, caricando un JSON come il seguente.
{
"id": "myid",
"title": "titolo",
"ttl": 3600
}Questo campo è supportato sia a livello di collezione che a livello di documento anche nella libreria .NET.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Gestire trasferimenti cloud con Azure Storage Mover
Esporre workflow come server MCP con Azure Logic Apps
Ridurre il reflow ottimizzando il CSS
Mappare una complex property di una entity su un campo JSON
Blazor e Static Web Assets in .NET 10
Integrare OpenTelemetry direttamente in Azure Monitor
Gestione dei codeowners in GitHub
Configuratione e utilizzo .NET Aspire CLI
Dallo sviluppo locale ad Azure con .NET Aspire
Abilitare il rolling update su Azure Functions flex consumption
Utilizzare Containers in .NET Aspire
Abilitare .NET 10 su Azure App Service e Azure Functions




