Modello dati

Firestore è un database NoSQL orientato ai documenti. A differenza di un database SQL, non ci sono tabelle o righe. Puoi invece archiviare i dati in documenti, che sono organizzati in raccolte.

Ogni documento contiene un insieme di coppie chiave-valore. Firestore è ottimizzato per archiviare grandi raccolte di piccoli documenti.

Tutti i documenti devono essere archiviati nelle raccolte. I documenti possono contenere sottoraccolte e oggetti nidificati, che possono entrambi includere campi primitivi come stringhe o oggetti complessi come elenchi.

Le raccolte e i documenti vengono creati implicitamente in Firestore. Assegna semplicemente i dati a un documento all'interno di una raccolta. Se la raccolta o il documento non esiste, Firestore lo crea.

Documenti

In Firestore, l'unità di archiviazione è il documento. Un documento è un record leggero contenente campi associati ai valori. Ogni documento è identificato da un nome.

Un documento che rappresenta un utente alovelace potrebbe avere il seguente aspetto:

  • alovelace

    first : "Ada"
    last : "Lovelace"
    born : 1815

Gli oggetti complessi e nidificati in un documento sono chiamati mappe. Ad esempio, puoi strutturare il nome dell'utente rispetto all'esempio precedente con una mappa, come riportato di seguito:

  • alovelace

    name :
        first : "Ada"
        last : "Lovelace"
    born : 1815

Potresti aver notato che i documenti sono molto simili a JSON. Di fatto sì. Esistono alcune differenze (ad esempio, i documenti supportano tipi di dati aggiuntivi e hanno dimensioni limitate a 1 MB), ma in generale puoi trattare i documenti come record JSON leggeri.

Raccolte

I documenti risiedono in raccolte, che sono semplicemente contenitori di documenti. Ad esempio, potresti avere una raccolta users che contiene i tuoi vari utenti, ciascuno rappresentato da un documento:

  • utenti

    • alovelace

      first : "Ada"
      last : "Lovelace"
      born : 1815

    • in tour

      first : "Alan"
      last : "Turing"
      born : 1912

Firestore è senza schema, quindi hai piena libertà su quali campi inserisci in ogni documento e quali tipi di dati vengono archiviati in tali campi. I documenti all'interno della stessa raccolta possono contenere tutti campi diversi oppure archiviare diversi tipi di dati in questi campi. Tuttavia, è buona norma utilizzare gli stessi campi e tipi di dati in più documenti, in modo da poter eseguire più facilmente la query sui documenti.

Una raccolta contiene documenti e nient'altro. Non può contenere direttamente campi non elaborati con valori e non può contenere altre raccolte. Consulta la sezione Dati gerarchici per una spiegazione di come strutturare dati più complessi in Firestore.

I nomi dei documenti all'interno di una raccolta sono univoci. Puoi fornire le tue chiavi, ad esempio gli ID utente, oppure puoi lasciare che Firestore crei automaticamente ID casuali.

Non è necessario "creare" o "eliminare" le raccolte. Dopo aver creato il primo documento in una raccolta, la raccolta esiste. Se elimini tutti i documenti in una raccolta, questo non esiste più.

Riferimenti

Ogni documento in Firestore è identificato in modo univoco dalla sua posizione all'interno del database. L'esempio precedente mostrava un documento alovelace nella raccolta users. Per fare riferimento a questa posizione nel codice, puoi creare un riferimento.

Versione web 9

import { doc } from "firebase/firestore";

const alovelaceDocumentRef = doc(db, 'users', 'alovelace');

Versione web 8

var alovelaceDocumentRef = db.collection('users').doc('alovelace');
Swift
Nota: questo prodotto non è disponibile per i target watchOS e per app clip.
let alovelaceDocumentRef = db.collection("users").document("alovelace")
Objective-C
Nota: questo prodotto non è disponibile per i target watchOS e per app clip.
FIRDocumentReference *alovelaceDocumentRef =
    [[self.db collectionWithPath:@"users"] documentWithPath:@"alovelace"];
Java
Android
DocumentReference alovelaceDocumentRef = db.collection("users").document("alovelace");
Kotlin+KTX
Android
val alovelaceDocumentRef = db.collection("users").document("alovelace")

Freccetto

final alovelaceDocumentRef = db.collection("users").doc("alovelace");
Java
// Reference to a document with id "alovelace" in the collection "users"
DocumentReference document = db.collection("users").document("alovelace");
Python
a_lovelace_ref = db.collection(u'users').document(u'alovelace')
Python
(asincrono)
a_lovelace_ref = db.collection("users").document("alovelace")
C++
DocumentReference alovelace_document_reference =
    db->Collection("users").Document("alovelace");
Node.js
const alovelaceDocumentRef = db.collection('users').doc('alovelace');
Go
alovelaceRef := client.Collection("users").Doc("alovelace")
PHP
$document = $db->collection('samples/php/users')->document('alovelace');
Unity
DocumentReference documentRef = db.Collection("users").Document("alovelace");
C#
DocumentReference documentRef = db.Collection("users").Document("alovelace");
Ruby
document_ref = firestore.col("users").doc("alovelace")

Un riferimento è un oggetto leggero che punta a una località nel tuo database. Puoi creare un riferimento se i dati sono presenti o meno e la creazione di un riferimento non esegue operazioni di rete.

Puoi anche creare riferimenti alle raccolte:

Versione web 9

import { collection } from "firebase/firestore";

const usersCollectionRef = collection(db, 'users');

Versione web 8

var usersCollectionRef = db.collection('users');
Swift
Nota:questo prodotto non è disponibile per i target watchOS e per app clip.
let usersCollectionRef = db.collection("users")
Objective-C
Nota: questo prodotto non è disponibile per i target watchOS e per app clip.
FIRCollectionReference *usersCollectionRef = [self.db collectionWithPath:@"users"];
Java
Android
CollectionReference usersCollectionRef = db.collection("users");
Kotlin+KTX
Android
val usersCollectionRef = db.collection("users")

Freccetto

final usersCollectionRef = db.collection("users");
Java
// Reference to the collection "users"
CollectionReference collection = db.collection("users");
Python
users_ref = db.collection(u'users')
Python
(asincrono)
users_ref = db.collection("users")
C++
CollectionReference users_collection_reference = db->Collection("users");
Node.js
const usersCollectionRef = db.collection('users');
Go
usersRef := client.Collection("users")
PHP
$collection = $db->collection('samples/php/users');
Unity
CollectionReference collectionRef = db.Collection("users");
C#
CollectionReference collectionRef = db.Collection("users");
Ruby
collection_ref = firestore.col "users"

Per comodità, puoi anche creare riferimenti specificando il percorso di un documento o di una raccolta come stringa, con i componenti del percorso separati da una barra (/). Ad esempio, per creare un riferimento al documento alovelace:

Versione web 9

import { doc } from "firebase/firestore";

const alovelaceDocumentRef = doc(db, 'users/alovelace');

Versione web 8

var alovelaceDocumentRef = db.doc('users/alovelace');
Swift
Nota:questo prodotto non è disponibile per i target watchOS e per app clip.
let aLovelaceDocumentReference = db.document("users/alovelace")
Objective-C
Nota: questo prodotto non è disponibile per i target watchOS e per app clip.
FIRDocumentReference *aLovelaceDocumentReference =
    [self.db documentWithPath:@"users/alovelace"];
Java
Android
DocumentReference alovelaceDocumentRef = db.document("users/alovelace");
Kotlin+KTX
Android
val alovelaceDocumentRef = db.document("users/alovelace")

Freccetto

final aLovelaceDocRef = db.doc("users/alovelace");
Java
// Reference to a document with id "alovelace" in the collection "users"
DocumentReference document = db.document("users/alovelace");
Python
a_lovelace_ref = db.document(u'users/alovelace')
Python
(asincrono)
a_lovelace_ref = db.document("users/alovelace")
C++
DocumentReference alovelace_document = db->Document("users/alovelace");
Node.js
const alovelaceDocumentRef = db.doc('users/alovelace');
Go
alovelaceRef := client.Doc("users/alovelace")
PHP
$document = $db->document('users/alovelace');
Unity
DocumentReference documentRef = db.Document("users/alovelace");
C#
DocumentReference documentRef = db.Document("users/alovelace");
Ruby
document_path_ref = firestore.doc "users/alovelace"

Dati gerarchici

Per capire come funzionano le strutture dei dati gerarchiche in Firestore, valuta un'app di chat di esempio con messaggi e stanze virtuali.

Puoi creare una raccolta chiamata rooms per archiviare diverse stanze virtuali:

  • stanze

    • stanzaA

      name : "my chat room"

    • stanzaB

      ...

Ora che disponi delle stanze virtuali, scegli come archiviare i messaggi. È consigliabile non memorizzarli nel documento della chat room. I documenti in Firestore devono essere leggeri e una stanza virtuale può contenere un numero elevato di messaggi. Tuttavia, puoi creare ulteriori raccolte all'interno del documento della stanza virtuale, come sottoraccolte.

Raccolte secondarie

Il modo migliore per archiviare i messaggi in questo scenario è utilizzare le sottoraccolte. Una sottoraccolta è una raccolta associata a un documento specifico.

Puoi creare una raccolta secondaria denominata messages per ogni documento della stanza virtuale nella raccolta rooms:

  • stanze

    • stanzaA

      name : "my chat room"

      • messaggi

        • messaggio1

          from : "alex"
          msg : "Hello World!"

        • messaggio2

          ...

    • stanzaB

      ...

In questo esempio, crei un riferimento a un messaggio nella raccolta secondaria con il seguente codice:

Versione web 9

import { doc } from "firebase/firestore";

const messageRef = doc(db, "rooms", "roomA", "messages", "message1");

Versione web 8

var messageRef = db.collection('rooms').doc('roomA')
                .collection('messages').doc('message1');
Swift
Nota:questo prodotto non è disponibile per i target watchOS e per app clip.
let messageRef = db
    .collection("rooms").document("roomA")
    .collection("messages").document("message1")
Objective-C
Nota:questo prodotto non è disponibile per i target watchOS e per app clip.
FIRDocumentReference *messageRef =
    [[[[self.db collectionWithPath:@"rooms"] documentWithPath:@"roomA"]
    collectionWithPath:@"messages"] documentWithPath:@"message1"];
Java
Android
DocumentReference messageRef = db
        .collection("rooms").document("roomA")
        .collection("messages").document("message1");
Kotlin+KTX
Android
val messageRef = db
        .collection("rooms").document("roomA")
        .collection("messages").document("message1")

Freccetto

final messageRef = db
    .collection("rooms")
    .doc("roomA")
    .collection("messages")
    .doc("message1");
Java
// Reference to a document in subcollection "messages"
DocumentReference document =
    db.collection("rooms").document("roomA").collection("messages").document("message1");
Python
room_a_ref = db.collection(u'rooms').document(u'roomA')
message_ref = room_a_ref.collection(u'messages').document(u'message1')
Python
(asincrono)
room_a_ref = db.collection("rooms").document("roomA")
message_ref = room_a_ref.collection("messages").document("message1")
C++
DocumentReference message_reference = db->Collection("rooms")
    .Document("roomA")
    .Collection("messages")
    .Document("message1");
Node.js
const messageRef = db.collection('rooms').doc('roomA')
  .collection('messages').doc('message1');
Go
messageRef := client.Collection("rooms").Doc("roomA").
	Collection("messages").Doc("message1")
PHP
$document = $db
    ->collection('rooms')
    ->document('roomA')
    ->collection('messages')
    ->document('message1');
Unity
DocumentReference documentRef = db
	.Collection("Rooms").Document("RoomA")
	.Collection("Messages").Document("Message1");
C#
DocumentReference documentRef = db
    .Collection("Rooms").Document("RoomA")
    .Collection("Messages").Document("Message1");
Ruby
message_ref = firestore.col("rooms").doc("roomA").col("messages").doc("message1")

Osserva il pattern alternato di raccolte e documenti. Le raccolte e i documenti devono sempre seguire questo schema. Non puoi fare riferimento a una raccolta in una raccolta o a un documento in un documento.

Le sottoraccolte consentono di strutturare i dati in modo gerarchico, rendendoli più facilmente accessibili. Per ricevere tutti i messaggi in roomA, puoi creare un riferimento alla raccolta per la raccolta secondaria messages e interagire con l'utente come qualsiasi altro riferimento raccolta.

I documenti contenuti nelle sottoraccolte possono contenere sottoraccolte, consentendovi di analizzare ulteriormente i dati nidificati. Puoi nidificare i dati fino a 100 livelli di profondità.