Pencarian khusus PostgreSQL

Kemiripan trigram

Pencarian trigram_similar mengizinkan anda melakukan pencarian triagram, mengukur angka dari triagram (tiga karakter berurutan) dibagi, menggunakan tambahan PostgreSQL keseluruhan. Sebuah pencarian triagram diberikan sebuah pernyataan dan mengembalikan hasil bahwa mempunyai pengukuran kemiripan lebih besar dari ambang kemiripan saat ini.

Untuk menggunakan itu, tambah 'django.contrib.postgres' dalam INSTALLED_APPS anda dan aktifkan pg_trgm extension di PostgreSQL. Anda dapat memasang tambahan menggunakan tindakan perpindahan TrigramExtension migration operation.

Pencarian trigram_similar dapat digunakan pada CharField dan TextField:

>>> City.objects.filter(name__trigram_similar="Middlesborough")
['<City: Middlesbrough>']

Unaccent

Pencarian unaccent mengizinkan anda melakukan pencarian aksen-peka menggunakan tambahan PostgreSQL khusus.

Pencarian ini diterapkan menggunakan Transform, jadi itu dapat diikat dengan fungsi pencarian lain. Untuk menggunakan itu, anda butuh menambah 'django.contrib.postgres' dalam INSTALLED_APPS anda dan mengaktifkan unaccent extension on PostgreSQL. Tindakan perpindahan UnaccentExtension tersedia jika anda ingin melakukan pengaktivan ini menggunakan perpindahan).

Pencarian unaccent dapat digunakan pada CharField dan TextField:

>>> City.objects.filter(name__unaccent="México")
['<City: Mexico>']

>>> User.objects.filter(first_name__unaccent__startswith="Jerem")
['<User: Jeremy>', '<User: Jérémy>', '<User: Jérémie>', '<User: Jeremie>']

Peringatan

Pencarian unaccent harus tampil baik dalam kebanyakan pengunaan kasus. Bagaimanapun, permintaan menggunakan penyaring ini akan umumnya melakukan pemindaian tabel penuh, yang dapat melambatkan pada tabel-tabel besar. Dalam kasus-kasus tersebut, menggunakan alat-alat pengindeksan teks penuh yang berdedikasi mungkin sesuai.