0

0

PHP开发:如何使用 Elasticsearch 实现全文检索

WBOY

WBOY

发布时间:2023-06-14 17:07:29

|

1660人浏览过

|

来源于php中文网

原创

在现代web应用程序中,数据量越来越大,但用户期望和对数据的访问也越来越广泛。因此,搜索技术变得越来越重要,能够满足用户的预期并提供更好的用户体验。全文搜索是一种强大的技术,能够快速索引、搜索和排序大量数据。在这方面,elasticsearch是一个领先的开源搜索引擎,它提供了许多先进的特性以及高可用性、易扩展性等优势。

在本篇文章中,将介绍如何通过PHP使用Elasticsearch实现全文检索。我们将从环境设置开始,包括Elasticsearch和PHP的安装,然后从索引、搜索和分析三个主要方面进行深入的介绍。

一、环境设置

首先,在本地或服务器上安装Elasticsearch。Elasticsearch可以从官方网站或者通过包管理器进行下载安装。

其次,通过Composer安装Elasticsearch的PHP客户端,也就是elasticsearch-php,它提供了许多方便的方法和类来调用Elasticsearch API。

立即学习PHP免费学习笔记(深入)”;

composer require elasticsearch/elasticsearch

安装完成后,在PHP文件中进行如下配置:

require 'vendor/autoload.php';

$client = ElasticsearchClientBuilder::create()->build();

这样,就创建了一个与Elasticsearch服务器通信的客户端。

二、索引

在Elasticsearch中,索引是一个用于存储和快速查找数据的数据集合。我们可以使用elasticsearch-php的API将数据插入到索引中。

  1. 创建一个索引

首先,我们需要创建一个新索引。我们通过以下代码,在名为“my_index”的索引中创建一个名为“my_type”的类型。

$params = [

'index' => 'my_index',
'body'  => [
    'mappings' => [
        'my_type' => [
            'properties' => [
                'title' => ['type' => 'text'],
                'body'  => ['type' => 'text'],
            ]
        ]
    ]
]

];

新快购物系统
新快购物系统

新快购物系统是集合目前网络所有购物系统为参考而开发,不管从速度还是安全我们都努力做到最好,此版虽为免费版但是功能齐全,无任何错误,特点有:专业的、全面的电子商务解决方案,使您可以轻松实现网上销售;自助式开放性的数据平台,为您提供充满个性化的设计空间;功能全面、操作简单的远程管理系统,让您在家中也可实现正常销售管理;严谨实用的全新商品数据库,便于查询搜索您的商品。

下载

$response = $client->indices()->create($params);

“properties”数组中的“title”和“body”字段类型为“text”,这意味着它们会进行全文索引。在实践中,我们会根据具体的需求来设置索引和字段类型。

这样,我们就成功创建了一个名为“my_index”的索引。

  1. 向索引中添加文档数据

使用以下代码将文档插入到索引中:

$params = [

'index' => 'my_index',
'type'  => 'my_type',
'body'  => [
    'title' => 'PHP Elasticsearch 全文检索',
    'body'  => 'Elasticsearch 是一个领先的全文搜索引擎,其功能包括分布式、高可用、实时搜索和分析能力等。',
]

];

$response = $client->index($params);

这里,我们将一篇带有标题和正文的文档插入到索引中。

  1. 更新文档

如果需要更新索引中已有的文档,使用以下代码:

$params = [

'index' => 'my_index',
'type'  => 'my_type',
'id'    => '1',
'body'  => [
    'doc' => [
        'title' => '修改后的标题',
        'body'  => '修改后的正文内容',
    ]
]

];

$response = $client->update($params);

需要注意的是,在更新时必须提供文档的ID。

  1. 删除文档

如果需要删除已经存在的文档,使用以下代码:

$params = [

'index' => 'my_index',
'type'  => 'my_type',
'id'    => '1'

];

$response = $client->delete($params);

这样,我们就完成了索引和文档的创建、插入、更新和删除。

三、搜索

我们来看一下如何使用elasticsearch-php的API来进行搜索。

  1. 简单查询

首先,让我们执行一个简单的查询:

$params = [

'index' => 'my_index',
'type'  => 'my_type',
'body'  => [
    'query' => [
        'match' => [
            'title' => 'PHP'
        ]
    ]
]

];

$response = $client->search($params);

在上面的代码中,我们执行了一个匹配查询,查询索引中所有包含“PHP”关键字的文档。搜索结果将存储在$response变量中。

  1. 多条件查询

如果需要查询多个条件,则可以使用bool查询来组合多个条件:

$params = [

'index' => 'my_index',
'type'  => 'my_type',
'body'  => [
    'query' => [
        'bool' => [
            'must' => [
                [ 'match' => [ 'title' => 'PHP' ] ],
                [ 'match' => [ 'body'  => '搜索引擎' ] ]
            ]
        ]
    ]
]

];

$response = $client->search($params);

这里,我们通过must参数指定了必须同时满足的两个查询条件。

  1. 分页查询

如果数据量很大,我们可以将搜索结果分页:

$params = [

'index' => 'my_index',
'type'  => 'my_type',
'body'  => [
    'from' => 0, 'size' => 10,
    'query' => [
        'match' => [
            'title' => 'PHP'
        ]
    ]
]

];

$response = $client->search($params);

通过from和size参数指定结果集的偏移量和大小。

  1. 按评分排序

为了获得更准确的搜索结果,Elasticsearch会为每个文档计算一个相关性评分。可以通过以下代码按评分进行排序:

$params = [

'index' => 'my_index',
'type'  => 'my_type',
'body'  => [
    'query' => [
        'match' => [
            'title' => 'PHP'
        ]
    ],
    'sort'  => [
        '_score' => [ 'order' => 'desc' ]
    ]
]

];

$response = $client->search($params);

这样查询结果将按相关性评分从高到低进行排序。

四、分析

Elasticsearch支持各种强大的分析和聚合功能,我们可以使用它们获取有关数据集的更深入信息。

  1. 聚合

以下代码可以获取“title”字段出现频率最高的前10个词:

$params = [

'index' => 'my_index',
'type'  => 'my_type',
'size'  => 0,
'body'  => [
    'aggs' => [
        'top_titles' => [
            'terms' => [
                'field' => 'title.keyword',
                'size'  => 10
            ]
        ]
    ]
]

];

$response = $client->search($params);

通过size参数指定跳过返回文档,并且仅返回聚合结果。

  1. 分析器

Elasticsearch还提供了许多强大的分析器来对文本进行分析和处理。以下代码演示了如何使用中文分析器来处理文本:

$params = [

'index' => 'my_index',
'body'  => [
    'settings' => [
        'analysis' => [
            'analyzer' => [
                'my_analyzer'   => [
                    'type'      => 'custom',
                    'tokenizer' => 'ik_max_word'
                ]
            ]
        ]
    ]
]

];

$response = $client->indices()->putSettings($params);

这里,我们为名为“my_analyzer”的分析器指定了“ik_max_word”分词器。

下面的代码可以使用这个分析器来分析文本:

$params = [

'index' => 'my_index',
'body'  => [
    'query' => [
        'query_string' => [
            'query'         => '搜索',
            'analyzer'      => 'my_analyzer',
            'default_field' => 'title'
        ]
    ]
]

];

$response = $client->search($params);

这样,我们就可以使用中文分析器来分析中文文本了。

总结

在本文中,我向您介绍了如何使用elasticsearch-php的API来创建、添加、更新和删除索引和文档,以及如何使用搜索API来执行简单和复杂的查询。此外,我还介绍了使用聚合和分析器来处理数据的相关技术。

随着数据集规模的增加,Elasticsearch的重要性逐渐增加。只要您熟悉它的API,您就可以通过PHP轻松地利用其强大的搜索和分析能力来优化您的Web应用程序。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

155

2023.12.25

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

466

2023.11.27

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

466

2023.11.27

数据库Delete用法
数据库Delete用法

数据库Delete用法:1、删除单条记录;2、删除多条记录;3、删除所有记录;4、删除特定条件的记录。更多关于数据库Delete的内容,大家可以访问下面的文章。

279

2023.11.13

drop和delete的区别
drop和delete的区别

drop和delete的区别:1、功能与用途;2、操作对象;3、可逆性;4、空间释放;5、执行速度与效率;6、与其他命令的交互;7、影响的持久性;8、语法和执行;9、触发器与约束;10、事务处理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

214

2023.12.29

什么是搜索引擎
什么是搜索引擎

搜索引擎是一种互联网工具,用于帮助用户在网上查找信息。搜索引擎的目标是提供最准确、最有价值的搜索结果,使用户能够快速找到所需的信息。本专题为大家提供搜索引擎相关的各种文章、以及下载和课程。

398

2023.08.02

有哪些目录搜索引擎
有哪些目录搜索引擎

目录搜索引擎有Google、Bing、Yahoo、Baidu、DuckDuckGo等。想了解更多目录搜索引擎的相关内容,可以阅读本专题下面的文章。

3221

2023.11.06

搜索引擎营销的主要模式
搜索引擎营销的主要模式

搜索引擎营销的主要模式包括:1. 竞价排名(ppc);2. 搜索引擎优化(seo);3. 本地搜索营销;4. 购物广告;5. 视频广告;6. 展示广告;7. 社交媒体营销;8. 移动广告。想了解更多搜索引擎营销的相关内容,可以阅读本专题下面的文章。

436

2024.05.20

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

54

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 10.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号