Penapisan Pertanyaan GAE yang Cekap
Artikel ini menangani isu biasa yang dihadapi semasa menapis pertanyaan Google App Engine (GAE). Masalah timbul apabila penapis nampaknya tidak berkuat kuasa, mengakibatkan hasil carian yang tidak dijangka.
Pertimbangkan coretan kod yang disediakan:
q := datastore.NewQuery("employee") q.Filter("Name =", "Andrew W")
Dalam contoh ini, matlamatnya adalah untuk mendapatkan semula entiti dengan sifat Nama khusus "Andrew W." Walau bagaimanapun, pertanyaan itu tidak berfungsi seperti yang diharapkan. Untuk menyelesaikan masalah ini, adalah penting untuk memahami bahawa Query.Filter() mengembalikan pertanyaan derivatif dengan penapis digunakan. Oleh itu, pendekatan yang betul adalah untuk menyimpan dan menggunakan nilai pulangan daripada Query.Filter().
q := datastore.NewQuery("employee").Filter("Name =", "Andrew W")
Sebagai alternatif, ini boleh ditulis dalam satu baris untuk ringkas:
q := datastore.NewQuery("employee").Filter("Name =", "Andrew W")
Satu lagi faktor penting untuk dipertimbangkan ialah ketekalan akhirnya, yang mempengaruhi operasi stor data dalam SDK pembangunan GAE. Ini bermakna pertanyaan yang dilaksanakan sejurus selepas operasi Put() mungkin tidak segera mengembalikan entiti yang disimpan. Untuk menangani perkara ini, kelewatan singkat boleh diperkenalkan sebelum menjalankan pertanyaan.
time.Sleep(time.Second) var e2 Employee q := datastore.NewQuery("employee").Filter("Name=", "Andrew W") // Rest of the code...
Untuk hasil yang sangat konsisten, pertimbangkan untuk menggunakan kunci ancestor semasa mencipta kunci. Kunci nenek moyang tidak wajib melainkan keputusan yang sangat konsisten diperlukan. Jika beberapa kelewatan dalam keputusan boleh diterima, kunci nenek moyang tidak diperlukan.
Ingat bahawa kunci nenek moyang boleh menjadi kunci fiksyen yang digunakan semata-mata untuk semantik dan tidak perlu mewakili entiti sedia ada. Entiti yang diberikan kunci nenek moyang yang sama membentuk kumpulan entiti dan pertanyaan nenek moyang pada kumpulan ini akan sangat konsisten.
Atas ialah kandungan terperinci Mengapa Pertanyaan Enjin Apl Google Saya Tidak Menapis dengan Betul?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!