A simple example of adding a document to the Firestore:
from google.cloud import firestore
#Make a note in the firestore
firestore_client = firestore.Client()
doc_ref = firestore_client.collection(u'CollectionsNameHere').add({
u'propertyone': u'thisisavalue',
u'propertytwo': 2,
})
logging.warning(doc_ref[1].id)
.add returns a tuple of the date that the document was written into the firestore, and a document reference to the written document. .add lets Firestore create a document ID to the written document: to figure out what the ID is, the last line accesses the tuple and pulls out the document ID.
An item that bit me: the official documentation for Firestore states that .add and .doc().set() are equivalent. That’s true, but the returns from both of those functions are different.
data:image/s3,"s3://crabby-images/06653/06653cf7d9a346d512e6369354857b76f52591e5" alt="Documentation from Google showing .add and .doc.set are the same operation."
.add returns a tuple of the document creation time and then a reference to the added document. However, .set returns a WriteResult, not a tuple. The WriteResult contains the time the document was updated/set in the property update_time. Make sure to use the correct function as necessary.
Set Documentation
data:image/s3,"s3://crabby-images/7832e/7832e2903abc72f0bf26d8eb4ff0f283e32bb6de" alt="Set Documentation - Firestore"
data:image/s3,"s3://crabby-images/5d94e/5d94e36e1aa3cc24f338d79d7ee8785907b98c13" alt="WriteResult documentation - Firestore."
Add Documentation
data:image/s3,"s3://crabby-images/dc0ca/dc0ca4c9d4a341eec19c6aaa5700cb5a59930669" alt="Add documentation - Firestore"