首页
/ Laravel Scout v10.13.0 版本发布:增强查询功能与类型支持

Laravel Scout v10.13.0 版本发布:增强查询功能与类型支持

2025-06-30 02:15:54作者:范靓好Udolf

Laravel Scout 是 Laravel 官方提供的全文搜索解决方案,它为开发者提供了简单优雅的 API 来集成各种搜索引擎服务。Scout 通过模型观察者自动保持搜索索引与数据库记录同步,支持 Algolia、Meilisearch、Typesense 等多种搜索引擎驱动。

主要更新内容

1. 增强 whereIn 和 whereNotIn 查询支持

本次更新中,Scout 对 whereInwhereNotIn 查询方法进行了功能扩展,现在开发者可以直接传递实现了 Arrayable 接口的对象作为查询条件。这一改进使得代码更加灵活和符合 Laravel 的惯用写法。

在实际应用中,我们经常需要处理集合或数组形式的数据。以前开发者需要手动调用 toArray() 方法转换数据,现在可以直接传递实现了 Arrayable 接口的对象,如 Eloquent 集合或 Laravel 的集合实例。

// 旧写法
$users = User::whereIn('id', $userIds->toArray())->get();

// 新写法 - 可以直接传递集合
$users = User::whereIn('id', $userIds)->get();

这一改进不仅减少了代码量,还提高了代码的可读性和一致性,特别是在处理复杂查询逻辑时。

2. 新增 afterRawSearch 回调功能

v10.13.0 版本引入了 afterRawSearch 回调功能,为开发者提供了在原始搜索查询执行后处理结果的能力。这个回调特别适合需要对搜索结果进行额外处理或转换的场景。

afterRawSearch 回调接收原始搜索结果作为参数,允许开发者在 Scout 返回结果前对其进行修改或增强。例如,可以添加额外的元数据、转换结果格式,或者基于结果执行其他操作。

Model::search('query')
    ->afterRawSearch(function ($results) {
        // 对原始搜索结果进行处理
        $results['processed'] = true;
        return $results;
    })
    ->get();

这一功能为高级搜索场景提供了更大的灵活性,特别是在需要与搜索引擎原生功能深度集成的情况下。

3. Typesense 驱动改进:自定义索引支持

对于使用 Typesense 作为搜索引擎的用户,本次更新修复了自定义索引支持的问题。Typesense 是一个开源的搜索引擎,以其高性能和易用性著称。

在之前的版本中,Scout 的 Typesense 驱动在处理自定义索引时可能存在一些问题。v10.13.0 版本确保了开发者可以无缝地使用自定义索引配置,这对于需要特殊索引结构或分片策略的应用场景尤为重要。

自定义索引允许开发者根据特定需求优化搜索性能和数据组织方式。例如,可以为不同数据类型创建专门的索引,或者为特定查询模式优化索引结构。

// 在模型中使用自定义索引
class Product extends Model
{
    public function searchableAs()
    {
        return 'custom_products_index';
    }
}

升级建议

对于正在使用 Laravel Scout 的项目,升级到 v10.13.0 版本是一个低风险的过程。这些改进主要添加了新功能而没有引入破坏性变更。不过,开发者应该:

  1. 测试项目中现有的 whereInwhereNotIn 查询,确保它们在新版本中按预期工作
  2. 如果使用 Typesense 驱动,验证自定义索引功能是否正常工作
  3. 考虑在适当的地方使用新的 afterRawSearch 回调来简化搜索结果处理逻辑

总结

Laravel Scout v10.13.0 通过增强查询构建器的灵活性、添加新的回调功能以及改进 Typesense 驱动支持,进一步提升了开发者的搜索体验。这些改进使得 Scout 在处理复杂搜索需求时更加得心应手,同时也保持了其简单易用的特点。

对于需要高级搜索功能的 Laravel 应用,特别是那些使用 Typesense 或需要精细控制搜索过程的项目,升级到这个版本将带来明显的开发效率提升。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
338
1.19 K
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
899
534
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
188
265
kernelkernel
deepin linux kernel
C
22
6
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
140
188
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
374
387
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.09 K
0
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
86
4
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
arkanalyzerarkanalyzer
方舟分析器:面向ArkTS语言的静态程序分析框架
TypeScript
115
45