PHPackages                             sciku1/laravel-match-against - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Database &amp; ORM](/categories/database)
4. /
5. sciku1/laravel-match-against

ActiveLibrary[Database &amp; ORM](/categories/database)

sciku1/laravel-match-against
============================

Laravel builder match against eloquent syntax and related.

0.1.1(8y ago)61.8k1MITPHP

Since Dec 14Pushed 7y ago1 watchersCompare

[ Source](https://github.com/sciku1/laravel-match-against)[ Packagist](https://packagist.org/packages/sciku1/laravel-match-against)[ RSS](/packages/sciku1-laravel-match-against/feed)WikiDiscussions master Synced today

READMEChangelog (2)Dependencies (2)Versions (3)Used By (0)

Laravel Match Against
=====================

[](#laravel-match-against)

A simple macro for doing match against fulltext searches with the Eloquent ORM api, currently in beta.

Requirements
------------

[](#requirements)

- Laravel 5.x
- MySQL 3.3+

`composer require sciku1/laravel-match-against`

Laravel 5.5
-----------

[](#laravel-55)

You're done!

Laravel 5.x
-----------

[](#laravel-5x)

You must register the service provider in your `config/app.php`

```
'providers' => [
    ...
    Sciku1\LaravelMatchAgainst\Providers\MatchAgainstServiceProvider::class,
]

```

Usage
-----

[](#usage)

To run match against queries, the field must have a fulltext index, currently there only way to do this is

```
DB::statement('ALTER TABLE `table_name` ADD FULLTEXT index_name(col1, col2)');

```

### Order

[](#order)

The default behaviour is to order. Example:

```
Model::match(['col1', 'col2'])->against('search terms')->get();

```

will generate

```
SELECT * FROM models ORDER BY (MATCH (col1) AGAINST ('search terms')) DESC, (MATCH (col2) AGAINST ('search terms')) DESC

```

### Where

[](#where)

To limit the results, you must use `whereAgainst()`

```
Model::match(['col1', 'col2'])->whereAgainst('search terms')->get();

```

will generate

```
SELECT * FROM models WHERE (MATCH (col1) AGAINST ('search terms')) > 0, (MATCH (col2) AGAINST ('search terms')) > 0

```

###  Health Score

29

—

LowBetter than 60% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity21

Limited adoption so far

Community8

Small or concentrated contributor base

Maturity54

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~3 days

Total

2

Last Release

3067d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/545371b4a94279041a61ef2ef7e4e16f57defd4592acae9a0ea9729fe2e42b33?d=identicon)[sciku1](/maintainers/sciku1)

---

Top Contributors

[![sciku1](https://avatars.githubusercontent.com/u/11371543?v=4)](https://github.com/sciku1 "sciku1 (22 commits)")

---

Tags

againstlaravelmacromatchmatch-againstlaravelormeloquentbuildermacrosmatch-against

### Embed Badge

![Health badge](/badges/sciku1-laravel-match-against/health.svg)

```
[![Health](https://phpackages.com/badges/sciku1-laravel-match-against/health.svg)](https://phpackages.com/packages/sciku1-laravel-match-against)
```

###  Alternatives

[tucker-eric/eloquentfilter

An Eloquent way to filter Eloquent Models

1.8k4.8M26](/packages/tucker-eric-eloquentfilter)[watson/validating

Eloquent model validating trait.

9723.3M47](/packages/watson-validating)[cybercog/laravel-love

Make Laravel Eloquent models reactable with any type of emotions in a minutes!

1.2k302.7k1](/packages/cybercog-laravel-love)[cviebrock/eloquent-taggable

Easy ability to tag your Eloquent models in Laravel.

567694.8k3](/packages/cviebrock-eloquent-taggable)[reedware/laravel-relation-joins

Adds the ability to join on a relationship by name.

2121.2M13](/packages/reedware-laravel-relation-joins)[io238/laravel-iso-countries

Ready-to-use Laravel models and relations for country (ISO 3166), language (ISO 639-1), and currency (ISO 4217) information with multi-language support.

5462.3k](/packages/io238-laravel-iso-countries)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
