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!