Rumah > pembangunan bahagian belakang > tutorial php > Pengoptimuman carian dan pengisihan produk Sphinx PHP dalam tapak web e-dagang

Pengoptimuman carian dan pengisihan produk Sphinx PHP dalam tapak web e-dagang

王林
Lepaskan: 2023-10-03 11:02:02
asal
900 orang telah melayarinya

Sphinx PHP 在电商网站中的商品搜索与排序优化

Pengoptimuman carian dan pengisihan produk Sphinx PHP dalam tapak web e-dagang

Dalam tapak web e-dagang, carian dan pengisihan produk adalah salah satu faktor penting untuk pengalaman pengguna dan penukaran jualan. Untuk meningkatkan pengalaman carian pengguna dan membentangkan hasil yang paling sepadan dengan keperluan pengguna, Sphinx PHP ialah enjin carian teks penuh yang sangat berkuasa dan digunakan secara meluas. Artikel ini akan memperkenalkan cara menggunakan Sphinx PHP untuk mengoptimumkan carian dan pengisihan produk di tapak web e-dagang, dan menyediakan contoh kod khusus.

1. Pasang dan konfigurasikan Sphinx PHP

Pertama, kita perlu memasang Sphinx PHP pada pelayan laman web e-dagang. Anda boleh memasangnya melalui arahan berikut:

$ pecl install sphinx
Salin selepas log masuk

Selepas pemasangan berjaya, anda perlu memperkenalkan Sphinx PHP ke dalam fail konfigurasi tapak web:

require_once 'sphinxapi.php';
Salin selepas log masuk

2. Wujudkan indeks produk

Sebelum menjalankan carian produk, anda perlu membuat indeks produk dalam Sphinx dahulu. Pertama, buat indeks yang dipanggil "produk". Andaikan jadual produk kami dinamakan "produk", yang mengandungi medan seperti id, nama, keterangan, harga, dll. Anda boleh membuat indeks melalui kod berikut:

$cl = new SphinxClient();
$cl->SetServer("localhost", 9312);
$cl->SetConnectTimeout(1);
$cl->SetArrayResult(true);

$cl->SetFieldWeights(array(
    'name' => 10,
    'description' => 5,
    'price' => 1
));

$cl->SetMatchMode(SPH_MATCH_ANY);
$cl->SetSortMode(SPH_SORT_RELEVANCE);

$cl->AddIndex('products');
$cl->AddQuery('iphone', 'products');

$result = $cl->RunQueries();

if ($result === false) {
    echo "搜索失败";
} else {
    foreach ($result['results'][0]['matches'] as $match) {
        echo "商品ID: " . $match['id'] . "<br>";
        echo "商品名称: " . $match['attrs']['name'] . "<br>";
        echo "商品描述: " . $match['attrs']['description'] . "<br>";
        echo "商品价格: " . $match['attrs']['price'] . "<br>";
        echo "<br>";
    }
}
Salin selepas log masuk

Kod di atas mula-mula mencipta objek SphinxClient dan menetapkan parameter sambungan dan berat medan , mod padanan dan mod isihan. Kemudian, nama indeks dan nama jadual yang hendak dicari ditentukan melalui kaedah AddIndex() dan kata kunci yang hendak dicari ditentukan melalui kaedah AddQuery(). Akhir sekali, carian dilakukan melalui kaedah RunQueries() dan hasil produk yang sepadan adalah output.

3. Optimumkan pengisihan produk

Apabila mencari produk, selain padanan kata kunci, anda juga perlu mempertimbangkan isu pengisihan. Berikut ialah contoh yang menunjukkan cara mengisih berdasarkan harga produk:

$cl = new SphinxClient();
$cl->SetServer("localhost", 9312);
$cl->SetConnectTimeout(1);
$cl->SetArrayResult(true);

$cl->SetFieldWeights(array(
    'name' => 10,
    'description' => 5,
    'price' => 1
));

$cl->SetMatchMode(SPH_MATCH_ANY);
$cl->SetSortMode(SPH_SORT_EXTENDED, '@yesno ASC, price ASC');

$cl->AddIndex('products');
$cl->AddQuery('iphone', 'products');

$result = $cl->RunQueries();

if ($result === false) {
    echo "搜索失败";
} else {
    foreach ($result['results'][0]['matches'] as $match) {
        echo "商品ID: " . $match['id'] . "<br>";
        echo "商品名称: " . $match['attrs']['name'] . "<br>";
        echo "商品描述: " . $match['attrs']['description'] . "<br>";
        echo "商品价格: " . $match['attrs']['price'] . "<br>";
        echo "<br>";
    }
}
Salin selepas log masuk

Dalam kod di atas, mod pengisihan ditetapkan kepada SPH_SORT_EXTENDED melalui kaedah SetSortMode() dan kemudian ditentukan oleh '@yesno ASC, harga ASC' kepada mula-mula ikut Medan tambahan (seperti sama ada untuk melekat pada bahagian atas) diisih, dan kemudian diisih mengikut harga.

Ringkasan:

Menggunakan Sphinx PHP untuk mengoptimumkan carian dan pengisihan produk di tapak web e-dagang boleh meningkatkan pengalaman carian pengguna dan membentangkan hasil yang paling sesuai dengan keperluan pengguna. Artikel ini memperkenalkan kaedah pemasangan dan konfigurasi Sphinx PHP, serta contoh kod khusus tentang cara membina indeks produk dan mengoptimumkan pengisihan produk. Saya harap artikel ini akan membantu pembangun yang menggunakan Sphinx PHP dalam laman web e-dagang.

Atas ialah kandungan terperinci Pengoptimuman carian dan pengisihan produk Sphinx PHP dalam tapak web e-dagang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan