


Cara menggunakan sambungan php Sphinx untuk carian teks penuh
Cara menggunakan sambungan PHP Sphinx untuk carian teks penuh
Carian teks penuh ialah salah satu keperluan biasa dalam aplikasi web moden. Untuk memenuhi pertanyaan cekap pengguna dan mendapatkan semula data, kami boleh menggunakan Sphinx, enjin carian sumber terbuka yang berkuasa, untuk melaksanakan fungsi carian teks penuh. Sphinx ditulis dalam C++ dan menyediakan sambungan PHP untuk kami gunakan dalam projek PHP.
Artikel ini akan memperkenalkan cara menggunakan sambungan PHP Sphinx untuk carian teks penuh. Pertama, kami perlu memastikan kami telah memasang dan mengkonfigurasi enjin Sphinx sebagai sumber data kami.
Langkah 1: Pasang enjin Sphinx
Kami boleh memuat turun versi terkini enjin Sphinx dari laman web rasmi Sphinx (http://sphinxsearch.com/downloads/release/). Selepas muat turun selesai, ikut arahan dalam dokumentasi rasmi untuk memasangnya.
Langkah 2: Konfigurasikan sumber data
Sebelum menggunakan Sphinx untuk carian teks penuh, kita perlu mengkonfigurasi sumber data dan memberitahu Sphinx di mana kandungan yang hendak dicari. Sphinx menyokong pelbagai sumber data, termasuk MySQL, PostgreSQL, XML dan banyak lagi.
Kami mengambil sumber data MySQL sebagai contoh Pertama, kami perlu mencipta jadual data dalam MySQL dan mengimport kandungan untuk dicari ke dalam jadual. Sebagai contoh, kami mencipta jadual yang dipanggil "filem" dan memasukkan tajuk dan sinopsis filem ke dalamnya.
CIPTA filem JADUAL (
id INT PRIMARY KEY, title VARCHAR(255), description TEXT
);
MASUKKAN KE DALAM filem (id, tajuk, penerangan) NILAI
(1, 'Avatar', 'A paraplegic marine dispatched to the moon Pandora on a unique mission becomes torn between following his orders and protecting the world he feels is his home.'), (2, 'The Avengers', 'Earth''s mightiest heroes must come together and learn to fight as a team if they are going to stop the mischievous Loki and his alien army from enslaving humanity.'), (3, 'Inception', 'A thief who steals corporate secrets through the use of dream-sharing technology is given the inverse task of planting an idea into the mind of a CEO.');
Simpan dan tutup pangkalan data MySQL.
Langkah 3: Konfigurasikan fail konfigurasi Sphinx
Dalam direktori pemasangan Sphinx, laksanakan arahan berikut untuk mencipta fail konfigurasi Sphinx baharu.
$ sudo cp sphinx.conf.dist sphinx.conf
Kemudian, buka fail sphinx.conf dan konfigurasikannya mengikut keperluan kita. Tambahkan yang berikut:
sumber filem {
type = mysql sql_host = localhost sql_user = username sql_pass = password sql_db = database sql_port = 3306 sql_query_pre = SET NAMES utf8 sql_query = SELECT id, title, description FROM movies sql_attr_uint = id sql_attr_uint = gid sql_query_info = SELECT * FROM movies WHERE id=$id
}
indeks filem {
source = movies path = /var/data/movies docinfo = extern min_prefix_len = 1 charset_type = utf-8
}
dicari {
listen = 9306:mysql41 log = /var/log/sphinxsearch/searchd.log query_log = /var/log/sphinxsearch/query.log read_timeout = 5 max_children = 30 pid_file = /var/run/sphinxsearch/searchd.pid seamless_rotate = 1 preopen_indexes = 1 unlink_old = 1 workers = threads binlog_path = /var/data/sphinxsearch/
}
Gantikan nama pengguna, kata laluan, pangkalan data anda dengan maklumat sambungan pangkalan data MySQL anda Simpan dan tutup fail konfigurasi sphinx.conf.
Langkah 4: Mulakan perkhidmatan Sphinx
Lakukan arahan berikut dalam terminal untuk memulakan perkhidmatan Sphinx.
$ searchd
Langkah 5: Buat skrip PHP
Kini kita boleh mencari data melalui skrip PHP. Buat fail bernama search.php dan masukkan kod berikut:
memerlukan 'sphinxapi.php';
$cl = new SphinxClient();
//Connect Sphinx service
$cl -> ;SetServer('localhost', 9312);
$cl->SetConnectTimeout(1);
$cl->SetArrayResult(true);
//Tetapkan mod carian dan kata kunci carian
$cl-> ;SetMatchMode(SetMatchMode(SetMatchMode) SPH_MATCH_EXTENDED2);
$cl->SetRankingMode(SPH_RANK_PROXIMITY_BM25);
$cl->SetSortMode(SPH_SORT_RELEVANCE);
$cl->SetLimits(0, 10;SetFitLimits(0, 10); tajuk' => 10, 'huraian' => 3));
echo 'Query failed: ' . $cl->GetLastError();
if ($cl->GetLastWarning()) { echo 'Warning: ' . $cl->GetLastWarning(); } echo 'Total matches: ' . $result['total_found'] . "
foreach ($result['matches'] as $match) { echo 'Title: ' . $match['attrs']['title']; echo 'Description: ' . $match['attrs']['description']; }
Dalam terminal, masukkan direktori di mana search.php terletak dan laksanakan arahan berikut:
Dengan langkah-langkah di atas, kami boleh menggunakan Sphinx untuk carian teks penuh dalam projek PHP Sphinx menyediakan banyak fungsi dan pilihan carian yang boleh dikonfigurasikan mengikut keperluan kami. Saya harap artikel ini dapat membantu anda memahami cara menggunakan PHP Sphinx untuk carian teks penuh
.
Atas ialah kandungan terperinci Cara menggunakan sambungan php Sphinx untuk carian teks penuh. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

Jika anda seorang pembangun PHP yang berpengalaman, anda mungkin merasakan bahawa anda telah berada di sana dan telah melakukannya. Anda telah membangunkan sejumlah besar aplikasi, menyahpenyahpepijat berjuta-juta baris kod dan mengubah suai sekumpulan skrip untuk mencapai op

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Tutorial ini menunjukkan cara memproses dokumen XML dengan cekap menggunakan PHP. XML (bahasa markup extensible) adalah bahasa markup berasaskan teks yang serba boleh yang direka untuk pembacaan manusia dan parsing mesin. Ia biasanya digunakan untuk penyimpanan data

Rentetan adalah urutan aksara, termasuk huruf, nombor, dan simbol. Tutorial ini akan mempelajari cara mengira bilangan vokal dalam rentetan yang diberikan dalam PHP menggunakan kaedah yang berbeza. Vokal dalam bahasa Inggeris adalah a, e, i, o, u, dan mereka boleh menjadi huruf besar atau huruf kecil. Apa itu vokal? Vokal adalah watak abjad yang mewakili sebutan tertentu. Terdapat lima vokal dalam bahasa Inggeris, termasuk huruf besar dan huruf kecil: a, e, i, o, u Contoh 1 Input: String = "TutorialSpoint" Output: 6 menjelaskan Vokal dalam rentetan "TutorialSpoint" adalah u, o, i, a, o, i. Terdapat 6 yuan sebanyak 6

Mengikat statik (statik: :) Melaksanakan pengikatan statik lewat (LSB) dalam PHP, yang membolehkan kelas panggilan dirujuk dalam konteks statik dan bukannya menentukan kelas. 1) Proses parsing dilakukan pada masa runtime, 2) Cari kelas panggilan dalam hubungan warisan, 3) ia boleh membawa overhead prestasi.

Apakah kaedah sihir PHP? Kaedah sihir PHP termasuk: 1. \ _ \ _ Membina, digunakan untuk memulakan objek; 2. \ _ \ _ Destruct, digunakan untuk membersihkan sumber; 3. \ _ \ _ Call, mengendalikan panggilan kaedah yang tidak wujud; 4. \ _ \ _ Mendapatkan, melaksanakan akses atribut dinamik; 5. \ _ \ _ Set, melaksanakan tetapan atribut dinamik. Kaedah ini secara automatik dipanggil dalam situasi tertentu, meningkatkan fleksibiliti dan kecekapan kod.
