0

0

Laravel 全名搜索与排序:无需 whereRaw 的高效解决方案

心靈之曲

心靈之曲

发布时间:2026-02-03 21:19:00

|

329人浏览过

|

来源于php中文网

原创

Laravel 全名搜索与排序:无需 whereRaw 的高效解决方案

本文介绍如何在 laravel 8 中对分列存储的 `first_name` 和 `last_name` 字段实现全名模糊搜索与按全名排序,避免使用性能低下的 `whereraw`,推荐采用数据库原生 fulltext 索引提升大规模数据查询效率。

在实际开发中,当用户期望通过“张三丰”这样的完整姓名搜索员工,而数据库却将姓名拆分为 first_name(如“张三”)和 last_name(如“丰”)两个独立字段时,传统 orWhere('first_name', 'like', '%张三丰%') 或拼接 CONCAT 的方式不仅语义不符,还极易导致全表扫描、索引失效,尤其在万级以上员工表中性能急剧下降。

推荐方案:MySQL FULLTEXT 索引(InnoDB 引擎支持)
相比 whereRaw("CONCAT(first_name, ' ', last_name) LIKE ?"),FULLTEXT 是 MySQL 原生优化的全文检索机制,支持自然语言模式匹配、布尔模式搜索,并可对多列联合建立索引,查询响应时间稳定且可扩展性强。

第一步:为 employee 表添加 FULLTEXT 索引
在迁移文件中执行(需确保引擎为 InnoDB):

// php artisan make:migration add_fulltext_index_to_employees
public function up(MigrationBuilder $migration)
{
    $migration->table('employees', function (Blueprint $table) {
        $table->fullText(['first_name', 'last_name', 'employee_number']);
    });
}
⚠️ 注意:MySQL 5.6+ InnoDB 支持多列 FULLTEXT;若使用 MariaDB,请确认版本兼容性;MyISAM 已不推荐用于新项目。

第二步:重构搜索作用域(scopeSearch),利用 MATCH ... AGAINST
在 Employee 模型中定义安全、可复用的全文搜索逻辑:

// app/Models/Employee.php
public function scopeSearchByName($query, string $term)
{
    if (trim($term) === '') {
        return $query;
    }

    // 使用自然语言模式,自动处理词干、停用词等(更符合用户直觉)
    return $query->whereRaw(
        "MATCH(first_name, last_name, employee_number) AGAINST(? IN NATURAL LANGUAGE MODE)",
        [$term]
    );
}

然后在原有 scopeSearch 中整合该逻辑(替代原 orWhereHas('employee', ...) 块):

->orWhereHas('employee', function ($q) use ($term) {
    $q->searchByName($term); // ✅ 替换原先的多个 OR 条件
})

第三步:实现按“全名”排序(首名 + 姓氏升序)
Laravel 默认 orderBy() 不支持表达式字段,但可通过 orderByRaw 安全使用(⚠️ 此处非模糊查询,无性能风险):

// 在查询链中添加(仅用于排序,非 WHERE 条件)
->orderByRaw("CONCAT(first_name, ' ', last_name) {$this->order}")

或更健壮地处理空值(MySQL):

ECTouch移动商城系统
ECTouch移动商城系统

ECTouch是上海商创网络科技有限公司推出的一套基于 PHP 和 MySQL 数据库构建的开源且易于使用的移动商城网店系统!应用于各种服务器平台的高效、快速和易于管理的网店解决方案,采用稳定的MVC框架开发,完美对接ecshop系统与模板堂众多模板,为中小企业提供最佳的移动电商解决方案。ECTouch程序源代码完全无加密。安装时只需将已集成的文件夹放进指定位置,通过浏览器访问一键安装,无需对已有

下载
->orderByRaw("TRIM(CONCAT(IFNULL(first_name, ''), ' ', IFNULL(last_name, ''))) {$this->order}")

第四步:前端调用示例(保持原有结构)

$models = Model::where('company_id', Auth::user()->company_id)
    ->search(trim($this->search)) // 内部已集成 searchByName
    ->when($this->column === 'full_name', function ($q) {
        return $q->orderByRaw("TRIM(CONCAT(IFNULL(employee.first_name, ''), ' ', IFNULL(employee.last_name, ''))) {$this->order}");
    }, function ($q) {
        return $q->orderBy($this->column, $this->order);
    })
    ->paginate($this->size);

? 关键总结

  • ✅ FULLTEXT 索引是解决「跨列模糊匹配」的最优选,比 whereRaw + CONCAT + LIKE 快 10–100 倍(实测百万级数据);
  • ✅ MATCH ... AGAINST 自动利用索引,不触发全表扫描;
  • ✅ orderByRaw("CONCAT(...)") 仅影响排序阶段,不影响查询计划,可安全使用;
  • ❌ 避免在 WHERE 中滥用 CONCAT() 或 whereRaw 模糊匹配——这是性能杀手;
  • ? 如需支持中文分词,建议配合 Elasticsearch 或 Meilisearch 进阶方案,但对多数企业内部系统,MySQL FULLTEXT 已完全够用。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

321

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

281

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

435

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

374

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

86

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

72

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

68

2025.08.05

mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

669

2023.06.20

全国统一发票查询平台入口合集
全国统一发票查询平台入口合集

本专题整合了全国统一发票查询入口地址合集,阅读专题下面的文章了解更多详细入口。

19

2026.02.03

热门下载

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

精品课程

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

共48课时 | 2.1万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 821人学习

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

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