sphinx是支持结果聚类的——WHERE、ORDER BY和GROUP BY

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

原生API提供的匹配筛选、排序和分组配置和SQL语法提供的WHERE、ORDER BY和GROUP BY语句的效果是一样的,你可以对匹配结果进行你需要的筛选、排序和分组匹配。例如,如果你要搜索MySQL中1990年代的书籍,并按照价格排序,可以这么写:

 
  1. $cl = new SphinxClient();
  2. $cl->SetFilterRange("year_published", 1990, 1999);
  3. $cl->SetSortMode(SPH_SORT_EXTENDED, "price DESC");
  4. $result = $cl->Query("mysql", "booksindex");

上述代码不仅一目了然而且也展示了通用API的使用模式:首先创建一个客户端对象,配置所有查询设置,然后启动搜索并获取结果。当然,产品级的代码应当添加错误处理:

 
  1. $cl = new SphinxClient();
  2. $cl->SetFilterRange("year_published", 1990, 1999);
  3. $cl->SetSortMode(SPH_SORT_EXTENDED, "price DESC");
  4. $result = $cl->Query("mysql", "booksindex");
  5. if (!$result)
  6. {
  7. // oops, there was an error
  8. DisplayErrorPage($cl->GetLastError());
  9. } else
  10. {
  11. // everything was good
  12. DisplaySearchResult($result);
  13. }

为了进一步完善,让我们也看看如何使用原生API来对年份来分组和计算数据:

 
  1. $cl = new SphinxClient();
  2. $cl->SetFilterRange("year_published", 1990, 1999);
  3. $cl->SetSortMode(SPH_SORT_EXTENDED, "price DESC");
  4. $cl->SetGroupBy("year_published", SPH_GROUPBY_ATTR);
  5. $cl->SetSelect("*, MIN(price) AS minprice,
  6. MAX(price) AS maxprice, AVG(price) AS avgprice");
  7. $result = $cl->Query("mysql", "booksindex");

你会发现,当我们进一步地为查询添加更多的处理时,代码也开始越来越像SQL了。但我们用的是零散的接口而不是单一的表达式来构建查询的。

 

摘自:https://www.zybuluo.com/lxjwlt/note/141406














本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/bonelee/p/6651290.html,如需转载请自行联系原作者

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
order by 、group by 、having的用法区别
order by 从英文里理解就是行的排序方式,默认的为升序。 order by 后面必须列出排序的字段名,可以是多个字段名。 group by 从英文里理解就是分组。必须有“聚合函数”来配合才能使用,使用时至少需要一个分组标志字段。 什么是“聚合函数”?像sum()、count()、avg()等都是“聚合函数”        使用group by 的目的就是要将数据分类汇总。
1246 0
PostgreSQL listagg within group (order by) 聚合兼容用法 string_agg ( order by) - 行列变换,CSV构造...
标签 PostgreSQL , order-set agg , listagg , string_agg , order 背景 listagg — Rows to Delimited Strings The listagg function transforms values from a g...
6425 0
|
18天前
【YashanDB知识库】update (子查询) set ORG_ID_STAN -ID 改写
【YashanDB知识库】update (子查询) set ORG_ID_STAN -ID 改写
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等