Artikel ini menerangkan pengesahan skema MongoDB menggunakan Validator $ JSonschema untuk menguatkuasakan integriti data. Ia memperincikan bagaimana untuk menentukan skema JSON yang menentukan jenis data, kekangan (misalnya, min/max), dan medan yang diperlukan. Amalan terbaik untuk skema de
Pengesahan skema MongoDB membolehkan anda menentukan peraturan untuk struktur dan kandungan dokumen anda, memastikan integriti data dan konsistensi. Ini dicapai melalui Validator $jsonSchema
dalam perintah createCollection
atau collMod
. Validator $jsonSchema
menggunakan dokumen skema JSON untuk menentukan bidang, jenis data, dan kekangan yang diperlukan untuk dokumen anda.
Sebagai contoh, katakan anda menyimpan maklumat mengenai pengguna. Anda ingin memastikan setiap dokumen pengguna mempunyai firstName
(rentetan), nama lastName
(rentetan), dan age
(integer), dan umurnya antara 0 dan 120. Anda akan menentukan skema JSON seperti ini:
<code class="json">{ "bsonType": "object", "properties": { "firstName": { "bsonType": "string", "description": "must be a string and is required" }, "lastName": { "bsonType": "string", "description": "must be a string and is required" }, "age": { "bsonType": "int", "minimum": 0, "maximum": 120, "description": "must be an integer between 0 and 120" } }, "required": [ "firstName", "lastName", "age" ] }</code>
Skema ini menyatakan bahawa dokumen itu mestilah objek, dan ia mentakrifkan bidang yang diperlukan dan jenis data mereka. Arahan required
memastikan bahawa firstName
, lastName
, dan age
hadir dalam setiap dokumen. Sifat minimum
dan maximum
menghalang medan age
. Anda kemudian memohon skema ini apabila membuat atau mengubahsuai koleksi menggunakan arahan createCollection
atau collMod
dengan pilihan validator
. Sebarang dokumen yang melanggar peraturan ini akan ditolak oleh MongoDB. Ini menghalang data yang tidak sah dari memasuki pangkalan data anda, mengekalkan integriti data.
Merancang skema MongoDB yang berkesan dengan pengesahan memerlukan pertimbangan yang teliti terhadap model data anda dan kes penggunaan yang berpotensi. Berikut adalah beberapa amalan terbaik:
required
dalam skema JSON anda.minimum
, maximum
, minLength
, maxLength
, pattern
(untuk ungkapan biasa), dan enum
untuk menguatkuasakan sekatan data.Apabila dokumen gagal pengesahan skema, MongoDB akan menolak operasi penyisipan atau kemas kini. Aplikasi anda perlu mengendalikan kesilapan ini dengan anggun. Kaedah khusus bergantung kepada pemacu dan bahasa pengaturcaraan anda. Umumnya, anda akan menerima mesej ralat yang menunjukkan kegagalan pengesahan dan sebabnya.
try...catch
(atau setaraf) untuk menangkap kesilapan pengesahan. Tidak, pengesahan skema terbina dalam MongoDB tidak menyokong fungsi pengesahan tersuai secara langsung. Validator $jsonSchema
bergantung pada kata kunci dan jenis data skema JSON yang telah ditetapkan. Walau bagaimanapun, anda boleh mencapai fungsi yang sama melalui cara lain:
$jsonSchema
, anda boleh melakukan pemeriksaan pasca pemprosesan dan audit untuk mengenal pasti ketidakkonsistenan. Ini mungkin melibatkan pertanyaan pangkalan data dan memeriksa data untuk mematuhi peraturan tersuai. Anda kemudian boleh membenderakan ketidakkonsistenan ini untuk semakan atau pembetulan.Ingat bahawa pengesahan peringkat aplikasi adalah penting untuk integriti data yang mantap. Walaupun pengesahan skema MongoDB menyediakan barisan pertahanan pertama, ia tidak boleh dipercayai sepenuhnya untuk keperluan pengesahan yang kompleks.
Atas ialah kandungan terperinci Bagaimana saya menggunakan pengesahan skema MongoDB untuk menguatkuasakan integriti data?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!