Cloud Firestore, NoSQL, belge tabanlı bir veritabanıdır. SQL veritabanlarından farklı olarak tablo veya satır yoktur. Bunun yerine, verileri koleksiyonlar halinde düzenlenen dokümanlarda depolarsınız.
Her doküman bir dizi anahtar/değer çifti içerir. Cloud Firestore, küçük dokümanlardan oluşan büyük koleksiyonları depolamak için optimize edilmiştir.
Tüm dokümanlar koleksiyonlarda depolanmalıdır. Belgeler, alt koleksiyonlar ve iç içe yerleştirilmiş nesneler içerebilir. Bunların her ikisi de dizeler veya listeler gibi karmaşık nesneleri içerebilir.
Koleksiyonlar ve dokümanlar Cloud Firestore ürününde dolaylı olarak oluşturulur. Koleksiyondaki bir dokümana veri atamanız yeterlidir. Koleksiyon veya belge mevcut değilse Cloud Firestore bunları oluşturur.
Dokümanlar
Cloud Firestore ürününde, depolama birimi dokümandır. Belge, değerlerle eşlenen alanlar içeren basit bir kayıttır. Her belge bir adla tanımlanır.
alovelace
kullanıcısını temsil eden bir doküman aşağıdaki gibi görünebilir:
alovelace
first : "Ada"
last : "Lovelace"
born : 1815
Bir dokümanda bulunan karmaşık, iç içe yerleştirilmiş nesnelere harita denir. Örneğin, yukarıdaki örnekteki kullanıcının adını bir harita ile şu şekilde yapılandırabilirsiniz:
alovelace
name :
first : "Ada"
last : "Lovelace"
born : 1815
Dokümanların JSON'a çok benzediğini fark edebilirsiniz. Öyle diyebiliriz. Bazı farklılıklar vardır (örneğin, dokümanlar ek veri türlerini destekler ve boyut olarak 1 MB ile sınırlıdır) ancak genel olarak dokümanları basit JSON kayıtları olarak değerlendirebilirsiniz.
Koleksiyonlar
Dokümanlar, dokümanlar için kapsayıcı olan koleksiyonlarda bulunur. Örneğin, her biri bir belgeyle temsil edilen, çeşitli kullanıcılarınızı içeren bir users
koleksiyonunuz olabilir:
kullanıcı
alovelace
first : "Ada"
last : "Lovelace"
born : 1815
aturing
first : "Alan"
last : "Turing"
born : 1912
Cloud Firestore şemasızdır. Bu sayede, her belgeye yerleştireceğiniz alanlar ve bu alanlarda hangi veri türlerini depolayacağınız konusunda tam bir özgürlüğe sahip olursunuz. Aynı koleksiyondaki belgelerin tümü farklı alanlar içerebilir veya bu alanlarda farklı veri türleri depolayabilir. Ancak dokümanları daha kolay sorgulayabilmek için birden fazla dokümanda aynı alanları ve veri türlerini kullanmak iyi bir fikirdir.
Koleksiyonlar yalnızca doküman içerir. Değer içeren ham alanları doğrudan içeremez ve başka koleksiyonlar içeremez. (Cloud Firestore ürününde daha karmaşık verilerin nasıl yapılandırılacağına ilişkin bir açıklama için Hiyerarşik Veriler'e bakın.)
Koleksiyondaki dokümanların adları benzersizdir. Kullanıcı kimlikleri gibi kendi anahtarlarınızı sağlayabilir veya Cloud Firestore'ün sizin için otomatik olarak rastgele kimlikler oluşturmasına izin verebilirsiniz.
Koleksiyon "oluşturmanız" veya "silmeniz" gerekmez. Koleksiyondaki ilk dokümanı oluşturduktan sonra koleksiyon oluşturulur. Bir koleksiyondaki tüm dokümanları silerseniz koleksiyon artık mevcut olmaz.
Referanslar
Cloud Firestore hizmetindeki her belge, veritabanındaki konumuyla benzersiz şekilde tanımlanır. Önceki örnekte, users
koleksiyonundaki alovelace
dokümanı gösterilmiştir. Kodunuzda bu konuma referans vermek için bir referans oluşturabilirsiniz.
Web
import { doc } from "firebase/firestore"; const alovelaceDocumentRef = doc(db, 'users', 'alovelace');
Web
var alovelaceDocumentRef = db.collection('users').doc('alovelace');
Swift
let alovelaceDocumentRef = db.collection("users").document("alovelace")
Objective-C
FIRDocumentReference *alovelaceDocumentRef = [[self.db collectionWithPath:@"users"] documentWithPath:@"alovelace"];
Kotlin+KTX
val alovelaceDocumentRef = db.collection("users").document("alovelace")
Java
DocumentReference alovelaceDocumentRef = db.collection("users").document("alovelace");
Dart
final alovelaceDocumentRef = db.collection("users").doc("alovelace");
Java
Python
Python
C++
DocumentReference alovelace_document_reference = db->Collection("users").Document("alovelace");
Node.js
Go
PHP
PHP
Cloud Firestore istemcisini yükleme ve oluşturma hakkında daha fazla bilgi için Cloud Firestore istemci kitaplıkları başlıklı makaleyi inceleyin.
Unity
DocumentReference documentRef = db.Collection("users").Document("alovelace");
C#
C#
Cloud Firestore istemcisi yükleme ve oluşturma hakkında daha fazla bilgi için Cloud Firestore İstemci Kitaplıkları'na bakın.
Ruby
Referans, yalnızca veritabanınızdaki bir konuma işaret eden hafif bir nesnedir. Burada veri olup olmamasına bakılmaksızın bir referans oluşturabilirsiniz. Referans oluşturmak, herhangi bir ağ işlemi gerçekleştirmez.
Koleksiyonlara da referans oluşturabilirsiniz:
Web
import { collection } from "firebase/firestore"; const usersCollectionRef = collection(db, 'users');
Web
var usersCollectionRef = db.collection('users');
Swift
let usersCollectionRef = db.collection("users")
Objective-C
FIRCollectionReference *usersCollectionRef = [self.db collectionWithPath:@"users"];
Kotlin+KTX
val usersCollectionRef = db.collection("users")
Java
CollectionReference usersCollectionRef = db.collection("users");
Dart
final usersCollectionRef = db.collection("users");
Java
Python
Python
C++
CollectionReference users_collection_reference = db->Collection("users");
Node.js
Go
PHP
PHP
Cloud Firestore istemcisi yükleme ve oluşturma hakkında daha fazla bilgi için Cloud Firestore İstemci Kitaplıkları'na bakın.
Unity
CollectionReference collectionRef = db.Collection("users");
C#
C#
Cloud Firestore istemcisini yükleme ve oluşturma hakkında daha fazla bilgi için Cloud Firestore istemci kitaplıkları başlıklı makaleyi inceleyin.
Ruby
Kolaylık sağlamak için bir belgenin veya koleksiyonun yolunu, yol bileşenleri eğik çizgiyle (/
) ayrılmış bir dize olarak belirterek de referans oluşturabilirsiniz. Örneğin, alovelace
belgesine referans oluşturmak için:
Web
import { doc } from "firebase/firestore"; const alovelaceDocumentRef = doc(db, 'users/alovelace');
Web
var alovelaceDocumentRef = db.doc('users/alovelace');
Swift
let aLovelaceDocumentReference = db.document("users/alovelace")
Objective-C
FIRDocumentReference *aLovelaceDocumentReference = [self.db documentWithPath:@"users/alovelace"];
Kotlin+KTX
val alovelaceDocumentRef = db.document("users/alovelace")
Java
DocumentReference alovelaceDocumentRef = db.document("users/alovelace");
Dart
final aLovelaceDocRef = db.doc("users/alovelace");
Java
Python
Python
C++
DocumentReference alovelace_document = db->Document("users/alovelace");
Node.js
Go
PHP
PHP
Cloud Firestore istemcisi yükleme ve oluşturma hakkında daha fazla bilgi için Cloud Firestore İstemci Kitaplıkları'na bakın.
Unity
DocumentReference documentRef = db.Document("users/alovelace");
C#
C#
Cloud Firestore istemcisini yükleme ve oluşturma hakkında daha fazla bilgi için Cloud Firestore istemci kitaplıkları başlıklı makaleyi inceleyin.
Ruby
Hiyerarşik Veriler
Hiyerarşik veri yapılarının Cloud Firestore'te nasıl çalıştığını anlamak için mesajlar ve sohbet odaları içeren örnek bir sohbet uygulamasını düşünün.
Farklı sohbet odalarını depolamak için rooms
adında bir koleksiyon oluşturabilirsiniz:
oda
odaA
name : "my chat room"
oda B
...
Sohbet odalarınız olduğuna göre mesajlarınızı nasıl depolayacağınıza karar verin. Bu dosyaları sohbet odasının dokümanında saklamak istemeyebilirsiniz. Cloud Firestore içindeki dokümanlar hafif olmalı ve sohbet odası çok sayıda mesaj içerebilir. Ancak sohbet odanızın dokümanında alt koleksiyonlar olarak ek koleksiyonlar oluşturabilirsiniz.
Alt koleksiyonlar
Bu senaryoda iletileri depolamanın en iyi yolu alt koleksiyonları kullanmaktır. Alt koleksiyon, belirli bir dokümanla ilişkili bir koleksiyondur.
rooms
koleksiyonunuzdaki her oda dokümanı için messages
adında bir alt koleksiyon oluşturabilirsiniz:
oda
oda A
name : "my chat room"
mesajlar
mesaj1
from : "alex"
msg : "Hello World!"
message2
...
odaB
...
Bu örnekte, aşağıdaki kodla alt koleksiyondaki bir iletiye referans oluşturursunuz:
Web
import { doc } from "firebase/firestore"; const messageRef = doc(db, "rooms", "roomA", "messages", "message1");
Web
var messageRef = db.collection('rooms').doc('roomA') .collection('messages').doc('message1');
Swift
let messageRef = db .collection("rooms").document("roomA") .collection("messages").document("message1")
Objective-C
FIRDocumentReference *messageRef = [[[[self.db collectionWithPath:@"rooms"] documentWithPath:@"roomA"] collectionWithPath:@"messages"] documentWithPath:@"message1"];
Kotlin+KTX
val messageRef = db .collection("rooms").document("roomA") .collection("messages").document("message1")
Java
DocumentReference messageRef = db .collection("rooms").document("roomA") .collection("messages").document("message1");
Dart
final messageRef = db .collection("rooms") .doc("roomA") .collection("messages") .doc("message1");
Java
Python
Python
C++
DocumentReference message_reference = db->Collection("rooms") .Document("roomA") .Collection("messages") .Document("message1");
Node.js
Go
PHP
PHP
Cloud Firestore istemcisi yükleme ve oluşturma hakkında daha fazla bilgi için Cloud Firestore İstemci Kitaplıkları'na bakın.
Unity
DocumentReference documentRef = db .Collection("Rooms").Document("RoomA") .Collection("Messages").Document("Message1");
C#
C#
Cloud Firestore istemcisi yükleme ve oluşturma hakkında daha fazla bilgi için Cloud Firestore İstemci Kitaplıkları'na bakın.
Ruby
Koleksiyonların ve dokümanların alternatif kalıbına dikkat edin. Koleksiyonlarınız ve dokümanlarınız her zaman bu kalıbı izlemelidir. Bir koleksiyondaki koleksiyona veya bir dokümanda dokümana referans veremezsiniz.
Alt koleksiyonlar, verileri hiyerarşik olarak yapılandırmanıza olanak tanıyarak verilere erişimi kolaylaştırır. roomA
altındaki tüm mesajları almak için messages
alt koleksiyonuna bir koleksiyon referansı oluşturabilir ve bu referansla diğer koleksiyon referanslarıyla yaptığınız gibi etkileşimde bulunabilirsiniz.
Alt koleksiyonlardaki belgeler, alt koleksiyonlar da içerebilir. Bu sayede verileri daha fazla iç içe yerleştirebilirsiniz. Verileri 100 düzeye kadar iç içe yerleştirebilirsiniz.