search
HomeBackend DevelopmentPHP TutorialHow to use php extension Sphinx for full text search

How to extend Sphinx for full-text search using PHP

Full-text search is one of the common requirements in modern web applications. In order to satisfy users' efficient query and retrieval of data, we can use Sphinx, a powerful open source search engine, to implement full-text search functionality. Sphinx is written in C and provides PHP extensions for us to use in PHP projects.

This article will introduce how to use PHP to extend Sphinx for full-text search. First, we need to make sure we have the Sphinx engine installed and configured as our data source.

Step one: Install Sphinx engine
We can download the latest version of Sphinx engine from Sphinx’s official website (http://sphinxsearch.com/downloads/release/). After the download is complete, follow the instructions in the official documentation to install it.

Step 2: Configure the data source
Before using Sphinx for full-text search, we need to configure the data source and tell Sphinx where the content to be searched is. Sphinx supports a variety of data sources, including MySQL, PostgreSQL, XML, and more.

We take the MySQL data source as an example. First, we need to create a data table in MySQL and import the content to be searched into the table. For example, we create a table called "movies" and insert the title and synopsis of the movie into it.

CREATE TABLE movies (

id INT PRIMARY KEY,
title VARCHAR(255),
description TEXT

);

INSERT INTO movies (id, title, description) VALUES

(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.');

Save and close the MySQL database.

Step 3: Configure Sphinx configuration file
In the Sphinx installation directory, execute the following command to create a new Sphinx configuration file.

$ sudo cp sphinx.conf.dist sphinx.conf

Then, open the sphinx.conf file and configure it according to our needs. Add the following:

source movies {

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

}

index movies {

source          = movies
path            = /var/data/movies
docinfo         = extern
min_prefix_len  = 1
charset_type    = utf-8

}

searchd {

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/

}

Replace username, password, and database with the connection information of your MySQL database. Save and close the sphinx.conf configuration file.

Step 4: Start the Sphinx service
Execute the following command in the terminal to start the Sphinx service.

$ searchd

Step 5: Create PHP script
Now we can search data through PHP script. Create a file called search.php and insert the following code:

require 'sphinxapi.php';

$cl = new SphinxClient( );

//Connect Sphinx service
$cl->SetServer('localhost', 9312);
$cl->SetConnectTimeout(1);
$cl-> ;SetArrayResult(true);

//Set search mode and search keywords
$cl->SetMatchMode(SPH_MATCH_EXTENDED2);
$cl->SetRankingMode(SPH_RANK_PROXIMITY_BM25);
$cl->SetSortMode(SPH_SORT_RELEVANCE);
$cl->SetLimits(0, 10);
$cl->SetFieldWeights(array('title' => 10, 'description' => ; 3));

$query = 'Avatar';

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

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

}

?>

Replace the search keywords with what you want to search for. Save and close the search.php file.

Step 6: Perform the search
In the terminal, enter the directory where search.php is located and execute the following Command:

$ php search.php

You will see that the results contain data matching the search keyword.

Through the above steps, we can Sphinx is used in the project for full-text search. Sphinx provides many powerful search functions and options that can be configured according to our needs. I hope this article can help you understand how to use PHP to extend Sphinx for full-text search.

The above is the detailed content of How to use php extension Sphinx for full text search. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
如何使用php扩展Sphinx进行全文搜索如何使用php扩展Sphinx进行全文搜索Jul 29, 2023 am 10:05 AM

如何使用PHP扩展Sphinx进行全文搜索全文搜索是现代Web应用程序中的常见需求之一。为了满足用户对数据的高效查询和检索,我们可以使用Sphinx这个功能强大的开源搜索引擎来实现全文搜索功能。Sphinx使用C++编写,提供了PHP的扩展,方便我们在PHP项目中使用。本文将介绍如何使用PHP扩展Sphinx进行全文搜索

PHP如何实现全文搜索功能,提供便捷的信息查找PHP如何实现全文搜索功能,提供便捷的信息查找Jun 27, 2023 am 09:04 AM

在现代网络应用开发中,全文搜索功能已经成为了必不可少的一部分。而PHP作为一个广泛应用于开发Web应用的语言,也自然而然地提供了一些功能强大的库来支持全文搜索。在这篇文章中,我们将深入探讨如何使用PHP实现全文搜索功能,并且提供一些小技巧,使你的信息查找更加便捷。一、什么是全文搜索?全文搜索是指在一篇文档中检索某个关键字或短语的能力。传统的搜索引擎通常只是简

如何使用PHP和SQLite进行全文搜索和索引策略如何使用PHP和SQLite进行全文搜索和索引策略Jul 29, 2023 pm 08:45 PM

如何使用PHP和SQLite进行全文搜索和索引策略引言:在现代的应用程序开发中,全文搜索功能在许多领域中都是不可或缺的。无论是在博客、新闻网站还是在电子商务平台上,用户都习惯使用关键字进行搜索。因此,为了提高用户体验并提供更好的搜索结果,我们需要使用适当的搜索和索引策略来提供全文搜索功能。在本文中,我们将探讨如何使用PHP和SQLite数据库来实现全文搜索和

如何使用MongoDB实现数据的全文搜索功能如何使用MongoDB实现数据的全文搜索功能Sep 19, 2023 pm 05:48 PM

如何使用MongoDB实现数据的全文搜索功能导语:随着信息化时代的迅猛发展,全文搜索功能成为了许多应用程序的必备功能。作为一个流行的NoSQL数据库,MongoDB也提供了强大的全文搜索能力。本文将介绍如何使用MongoDB实现数据的全文搜索功能,并提供相关的代码示例。一、MongoDB全文搜索功能简介MongoDB的全文搜索功能是通过MongoDB的文本索

如何使用 PHP 实现全文搜索和关键字提取功能如何使用 PHP 实现全文搜索和关键字提取功能Sep 05, 2023 pm 02:00 PM

如何使用PHP实现全文搜索和关键字提取功能全文搜索和关键字提取是现代网站和应用程序中常见的功能,可以为用户提供更好的搜索体验和相关推荐。在PHP中,我们可以使用全文索引和关键字提取的技术来实现这些功能。本文将介绍如何使用PHP实现全文搜索和关键字提取功能,并提供相应的代码示例。全文搜索功能的实现全文搜索是指在文本内容中搜索包含指定关键字的记录。在

如何在PHP7.0中实现一个全文搜索引擎?如何在PHP7.0中实现一个全文搜索引擎?May 26, 2023 pm 04:51 PM

随着信息时代的不断发展,人们越来越依赖互联网来获取信息。而作为信息分享的平台之一,网页搜索引擎也在不断进化和完善。本文将介绍如何在PHP7.0中实现一个全文搜索引擎,帮助读者更好地利用PHP技术,快速构建高效率的搜索引擎。一、全文搜索引擎概述全文搜索即使用关键词或短语在整篇文档中进行搜索,以找到最匹配的结果。全文搜索引擎使用算法对文档进行索引,以加速搜索。在

如何通过PHP和Elasticsearch快速实现全文搜索如何通过PHP和Elasticsearch快速实现全文搜索Jul 17, 2023 pm 05:17 PM

如何通过PHP和Elasticsearch快速实现全文搜索全文搜索在现代应用程序中变得越来越重要,它可以帮助用户快速找到他们需要的信息。Elasticsearch是一个强大的开源搜索引擎,它提供了快速和高效的全文搜索功能。结合PHP的强大功能和Elasticsearch的灵活性,我们可以轻松地实现全文搜索功能。本文将向您展示如何使用PHP和Elasticse

在PHP中使用Solr进行全文搜索在PHP中使用Solr进行全文搜索Jun 20, 2023 am 09:12 AM

Solr是一个基于Lucene的搜索引擎,可以用于实现全文搜索。在PHP中使用Solr进行全文搜索,可以帮助我们快速地通过关键词查询到相关的数据,提高搜索结果的准确性和可靠性。本文将为大家介绍如何在PHP中使用Solr进行全文搜索。一、Solr的安装与配置首先,我们需要在服务器上安装Solr和PHP的Solr扩展。Solr的安装步骤可以参考Solr的官方文档

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Tools

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools