Firestore dalam mode Datastore (Datastore) mendukung berbagai jenis data untuk nilai properti. Hal ini mencakup, antara lain:
- Bilangan bulat
- Angka floating-point
- String
- Tanggal
- Data biner
Untuk mengetahui daftar lengkap dari jenis, lihat Properti dan jenis nilai.
Properti dan jenis nilai
Nilai data yang terkait dengan entity terdiri dari satu atau beberapa properti. Setiap properti memiliki nama dan satu atau beberapa nilai. Properti dapat memiliki nilai yang berisi lebih dari satu jenis, dan dua entity dapat memiliki nilai dari jenis yang berbeda untuk properti yang sama. Properti dapat diindeks atau tidak diindeks (kueri yang mengurutkan atau memfilter pada properti P akan mengabaikan entity jika P tidak diindeks). Entity dapat memiliki maksimal 20.000 properti yang diindeks.
Jenis nilai berikut ini didukung:
Jenis nilai | Jenis Java | Tata urutan | Notes |
---|---|---|---|
Bilangan Bulat | short int long java.lang.Short java.lang.Integer java.lang.Long |
Angka | Disimpan sebagai bilangan bulat panjang, lalu dikonversi ke jenis kolom Nilai di luar rentang yang berlebih |
Angka floating-point | float double java.lang.Float java.lang.Double |
Angka | Presisi ganda 64-bit, IEEE 754 |
Boolean | boolean java.lang.Boolean |
false <true |
|
String teks (singkat) | java.lang.String |
Unicode | Hingga 1.500 byte Nilai yang lebih besar dari 1.500 byte menampilkan IllegalArgumentException |
String teks (panjang) | com.google.appengine.api.datastore.Text |
Tidak ada | Hingga 1 megabyte Tidak diindeks |
String byte (pendek) | com.google.appengine.api.datastore.ShortBlob |
Urutan byte | Hingga 1.500 byte Nilai yang lebih panjang dari 1.500 byte menampilkan IllegalArgumentException |
String byte (panjang) | com.google.appengine.api.datastore.Blob |
Tidak ada | Hingga 1 megabyte Tidak diindeks |
Tanggal dan waktu | java.util.Date |
Kronologis | |
Titik geografis | com.google.appengine.api.datastore.GeoPt |
Berdasarkan lintang, lalu bujur |
|
Alamat pos | com.google.appengine.api.datastore.PostalAddress |
Unicode | |
Nomor telepon | com.google.appengine.api.datastore.PhoneNumber |
Unicode | |
Alamat email | com.google.appengine.api.datastore.Email |
Unicode | |
Pengguna Akun Google | com.google.appengine.api.users.User |
Alamat email berdasarkan urutan Unicode |
|
Handle fitur pesan instan | com.google.appengine.api.datastore.IMHandle |
Unicode | |
Link | com.google.appengine.api.datastore.Link |
Unicode | |
Kategori | com.google.appengine.api.datastore.Category |
Unicode | |
Rating | com.google.appengine.api.datastore.Rating |
Angka | |
Kunci Datastore | com.google.appengine.api.datastore.Key atau objek yang direferensikan (sebagai turunan) |
Menurut elemen jalur (jenis, ID, jenis, ID...) |
Hingga 1.500 byte Nilai yang lebih panjang dari 1.500 byte menampilkan IllegalArgumentException |
Kunci Blobstore | com.google.appengine.api.blobstore.BlobKey |
Urutan byte | |
Entity tersemat | com.google.appengine.api.datastore.EmbeddedEntity |
Tidak ada | Tidak diindeks |
Null | null |
Tidak ada |
Penting: Sebaiknya jangan menyimpan users.User
sebagai nilai properti karena nilai ini menyertakan alamat email beserta ID uniknya. Jika pengguna mengubah alamat emailnya dan Anda membandingkan
user.User
lamanya yang tersimpan dengan nilai user.User
yang baru, nilai tersebut tidak akan cocok. Sebagai gantinya, gunakan nilai ID pengguna User
sebagai ID unik stabil pengguna.
Untuk string teks dan data biner yang tidak dienkode (string byte), Datastore mendukung dua jenis nilai:
- String pendek (hingga 1.500 byte) diindeks dan dapat digunakan dalam kondisi filter kueri dan tata urutan.
- String panjang (hingga 1 megabyte) tidak diindeks serta tidak dapat digunakan dalam filter kueri dan tata urutan.
Blob
di Datastore API. Jenis ini tidak terkait dengan blob seperti yang digunakan dalam Blobstore API.
Jika kueri melibatkan properti dengan nilai jenis campuran, Datastore akan menggunakan pengurutan deterministik berdasarkan representasi internal:
- Nilai null
- Angka fixed-point
- Bilangan bulat
- Tanggal dan waktu
- Rating
- Nilai boolean
- Urutan byte
- String byte
- String Unicode
- Kunci Blobstore
- Angka floating-point
- Titik geografis
- Pengguna Akun Google
- Kunci Datastore
Karena string teks panjang, string byte panjang, dan entitas tersemat tidak diindeks, urutannya juga tidak ditentukan.
Properti berulang
Anda dapat menyimpan beberapa nilai dalam satu properti.
Entity tersemat
Terkadang mungkin lebih nyaman untuk menyematkan satu entity sebagai properti entity lain. Hal ini dapat berguna, misalnya, untuk membuat struktur hierarki nilai properti dalam entity. Class Java EmbeddedEntity
memungkinkan Anda melakukan ini:
Properti entity tersemat tidak diindeks dan tidak dapat digunakan dalam kueri. Anda dapat memilih untuk mengaitkan kunci dengan entity tersemat, tetapi (tidak seperti entity lengkap) kunci tersebut tidak diperlukan dan, meskipun ada, tidak dapat digunakan untuk mengambil entity.
Daripada mengisi properti entity tersemat secara manual, Anda dapat menggunakan metode setPropertiesFrom()
untuk menyalinnya dari entity yang sudah ada:
Anda dapat menggunakan metode yang sama di lain waktu untuk memulihkan entity asli dari entity tersemat:
Menggunakan daftar kosong
Datastore secara historis tidak memiliki representasi untuk properti yang mewakili daftar kosong. Java SDK mengatasi masalah ini dengan menyimpan koleksi kosong sebagai nilai null, sehingga tidak ada cara untuk membedakan antara nilai null dan daftar kosong. Untuk mempertahankan kompatibilitas mundur, perilaku ini tetap default, yang disimpulkan sebagai berikut:
- Properti null ditulis sebagai null ke Datastore
- Koleksi kosong ditulis sebagai null ke Datastore
- Nilai null dibaca sebagai null dari Datastore
- Koleksi kosong dibaca sebagai null.
Namun, jika Anda mengubah perilaku default, Appengine Datastore Java SDK akan mendukung penyimpanan daftar kosong. Sebaiknya pertimbangkan dampak dari perubahan perilaku default aplikasi, lalu aktifkan dukungan untuk daftar kosong.
Untuk mengubah perilaku default agar Anda dapat menggunakan daftar kosong, tetapkan properti DATASTORE_EMPTY_LIST_SUPPORT selama inisialisasi aplikasi sebagai berikut:
System.setProperty(DatastoreServiceConfig.DATASTORE_EMPTY_LIST_SUPPORT, Boolean.TRUE.toString());
Dengan properti ini ditetapkan ke true
, seperti yang ditunjukkan di atas:
- Properti null ditulis sebagai null ke Datastore
- Koleksi kosong ditulis sebagai daftar kosong untuk Datastore
- Nilai null dibaca sebagai null dari Datastore
- Saat membaca dari Datastore, daftar kosong akan ditampilkan sebagai Koleksi kosong.