nld-labs/laravel-search 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

nld-labs/laravel-search

最新稳定版本:0.2.1

Composer 安装命令:

composer require nld-labs/laravel-search

包简介

Search trait for Laravel Eloquent models with multiple search strategies.

README 文档

README

Latest Version on Packagist

A search trait for Laravel Eloquent models with multiple search strategies. Splits the search term into words, matches each word against every specified field, and supports per-field strategy selection with database-aware query building.

Requirements

  • PHP ≥ 8.2
  • Laravel 11 or 12

Installation

composer require nld-labs/laravel-search

Quick Start

Add the Searchable trait to any Eloquent model:

use NLD\Search\Searchable;
use NLD\Search\SearchStrategy;

class Post extends Model
{
    use Searchable;
}

Then call the search scope:

Post::search('laravel auth', 'title,body')->get();

Search Strategies

Strategy Behaviour SQL
START_OF_WORDS Matches the term at the beginning of any word in the field. Uses ~* on PostgreSQL, REGEXP on MySQL/MariaDB, falls back to LIKE on SQLite. "field" ~* '\yterm'
IN_WORDS Matches the term anywhere inside the field value. "field" LIKE '%term%'
START_OF_STRING Matches the term at the very beginning of the field value. "field" LIKE 'term%'
EXACT Matches the term exactly. "field" = 'term'

The default strategy is START_OF_WORDS.

Specifying Fields

Comma-separated string

All fields use the default strategy (START_OF_WORDS, or the model's $searchStrategy property):

Post::search('term', 'title,body')->get();

Array with explicit strategies

Post::search('term', [
    'title' => SearchStrategy::START_OF_WORDS,
    'body'  => SearchStrategy::IN_WORDS,
    'slug'  => SearchStrategy::START_OF_STRING,
    'code'  => SearchStrategy::EXACT,
])->get();

Mixed array

Fields without a key use the default strategy:

Post::search('term', [
    'title',                              // uses default strategy
    'body' => SearchStrategy::IN_WORDS,   // explicit strategy
])->get();

Dot notation

Dot-notation field names are wrapped as qualified column references:

Post::search('term', [
    'posts.title' => SearchStrategy::IN_WORDS,
])->get();

Model Configuration

You can set default searchable fields and a default strategy directly on the model:

use NLD\Search\Searchable;
use NLD\Search\SearchStrategy;

class Post extends Model
{
    use Searchable;

    protected array $searchable = [
        'title' => SearchStrategy::START_OF_WORDS,
        'body'  => SearchStrategy::IN_WORDS,
    ];

    // Optional: override the default strategy for fields passed without one
    protected SearchStrategy $searchStrategy = SearchStrategy::IN_WORDS;
}

When $searchable is defined, calling search without fields uses it automatically:

Post::search('term')->get();

Fields passed explicitly always take precedence over the model property.

How It Works

  1. The search term is split into words (whitespace-separated, max 10 words).
  2. Each word produces a WHERE clause (ANDed together — every word must match).
  3. Inside each clause, every field produces an OR condition — matching any field is enough.
  4. Field names are validated against [a-zA-Z_][a-zA-Z0-9_.]*; invalid names are silently skipped.
  5. LIKE wildcards (%, _, \) and regex metacharacters are properly escaped.

Testing

./vendor/bin/pest

License

MIT © Vitauts Stočka. See LICENSE for details.

统计信息

  • 总下载量: 19
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-02-06

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固