Rumah >pembangunan bahagian belakang >tutorial php >Cara menggunakan sambungan php Sphinx untuk carian teks penuh

Cara menggunakan sambungan php Sphinx untuk carian teks penuh

WBOY
WBOYasal
2023-07-29 10:05:101194semak imbas

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:

050d337e4c14575b417ef0c3093b0c85SetConnectTimeout(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));

$query = 'Avatar';

$result = $cl->Query($query, 'movies');

jika ( $result === false) {

echo 'Query failed: ' . $cl->GetLastError();

} else {

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'];
}

}

?>

Gantikan kata kunci carian dengan perkara yang anda mahu cari. Simpan dan tutup carian. fail php.

Langkah 6: Lakukan carian

Dalam terminal, masukkan direktori di mana search.php terletak dan laksanakan arahan berikut:

$ php search.php

Anda akan melihat bahawa keputusan mengandungi padanan dengan kata kunci carian

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn