whereIn(...)"; 2. Filter data through filter; 3. Set the sorted data to "$data = $scoutModelsLists;"."/> whereIn(...)"; 2. Filter data through filter; 3. Set the sorted data to "$data = $scoutModelsLists;".">
search
HomePHP FrameworkLaravelHow to solve laravel sorting failure problem

Solution to laravel sorting failure: 1. Query data through "$query->whereIn(...)"; 2. Filter data through filter; 3. Set the sorted data to "$data = $scoutModelsLists;".

How to solve laravel sorting failure problem

The operating environment of this article: Windows 7 system, Laravel version 5.8, Dell G3 computer.

How to solve laravel sorting failure problem?

Laravel 5.8 scout7.0 Sorting failure solution using orderBy

Recently, when searching using elasticSearch6.2.4, I found that the sorting field is invalid, so here Record

Let’s take a look at the solution first. Without further ado, let’s go directly to the code

$list = Article::search($words)->orderBy('created_at','desc')->paginateRaw(10)->toArray();
$results = $list['data'];
if ($results['hits']['total'] === 0) {
    return $this->model->newCollection();
}
$builder =new Builder(new static(),$this->model->newModelQuery());
$keys = collect($results['hits']['hits'])->pluck('_id')->values()->all();
$query = $this->newQuery();
if ($builder->queryCallback) {
    call_user_func($builder->queryCallback, $query);
}
//查询数据
$scoutModelsLists = $query->whereIn(
    $this->model->qualifyColumn($this->model->getKeyName()), $keys
)->orderBy('created_at','desc')->get();
//过滤数据
$scoutModelsLists->filter(function () use ($keys) {
    return in_array($this->model->getKey(), $keys);
});
//这里为最终排序好的数据
$data = $scoutModelsLists;

Problem analysis

The original query statement used is

$list = Article::search($words)->orderBy('created_at','desc')->paginate(10)->toArray();

Although the above query statement sets the sorting field, it is not sorted when it is finally output. After analysis, it is indeed sorted in the ES search results, but when it is finally output, the ES data structure is converted into a set. , no sorting field is added

Code analysis

File 1: /vendor/laravel/scout/src/builder.php About 261 lines - 305 lines

If you look closely at this file, there will be two methods: paginate and paginateRaw. The former returns the laravel collection, and the latter returns the native query structure of es.

The difference between the two codes lies in this block

$results = $this->model->newCollection($engine->map(
        $this, $rawResults = $engine->paginate($this, $perPage, $page), $this->model
    )->all());

File 2: vendor/tamayo/laravel-scout-elastic/src/ElasticsearchEngine.php Line 211, map method, because here we are using the ES engine, if you use other, it may be different, the code:

public function map(Builder $builder, $results, $model)
{
//无数据返回空集合
if ($results['hits']['total'] === 0) {
    return $model->newCollection();
}
//获取所有键为_id的ES数据
//$keys = collect($results['hits']['hits'])->pluck('_id')->values()->all();
//转化ES数据并过滤
return $model->getScoutModelsByIds(
        $builder, $keys
    )->filter(function ($model) use ($keys) {
        return in_array($model->getScoutKey(), $keys);
    });
}

From the code point of view, if es searches for data, it will be converted and filtered to return a set that meets the conditions. If it is not satisfied, it will directly return empty

File 3: /vendor/laravel/scout/ src/Searchable.php is about 171 lines getScoutModelsByIds method, code

public function getScoutModelsByIds(Builder $builder, array $ids)
{
//加入软删除
$query = static::usesSoftDelete()
    ? $this->withTrashed() : $this->newQuery();
if ($builder->queryCallback) {
    call_user_func($builder->queryCallback, $query);
}
// 重点这里,自改代码
// return $query->whereIn(
  //   $this->getScoutKeyName(), $ids
// )->orderBy('orderBy','desc')->get();
//官方代码
return $query->whereIn(
    $this->getScoutKeyName(), $ids
)->get();
}

This file is the focus, mainly because the orderBy sorting field is not added when the final return is made, so although es is sorted in the final output, here again It has been reset. In order to prevent other places from being unable to update after changing the component, sorting is added when the data is finally returned. Please refer to the beginning of the article for the plan.

It’s over for the time being, and I’ll improve it when it’s empty.

The latest five Laravel video tutorials (recommended)

The above is the detailed content of How to solve laravel sorting failure problem. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Laravel (PHP) vs. Python: Different Use Cases and ApplicationsLaravel (PHP) vs. Python: Different Use Cases and ApplicationsApr 18, 2025 am 12:16 AM

Selecting Laravel or Python depends on the project requirements: 1) If you need to quickly develop web applications and use ORM and authentication systems, choose Laravel; 2) If it involves data analysis, machine learning or scientific computing, choose Python.

Laravel and Python: Finding the Right ToolLaravel and Python: Finding the Right ToolApr 18, 2025 am 12:14 AM

Laravel is suitable for building web applications quickly, and Python is suitable for projects that require flexibility and versatility. 1) Laravel provides rich features such as ORM and routing, suitable for the PHP ecosystem. 2) Python is known for its concise syntax and a powerful library ecosystem, and is suitable for fields such as web development and data science.

Laravel and PHP: Creating Dynamic WebsitesLaravel and PHP: Creating Dynamic WebsitesApr 18, 2025 am 12:12 AM

Use Laravel and PHP to create dynamic websites efficiently and fun. 1) Laravel follows the MVC architecture, and the Blade template engine simplifies HTML writing. 2) The routing system and request processing mechanism make URL definition and user input processing simple. 3) EloquentORM simplifies database operations. 4) The use of database migration, CRUD operations and Blade templates are demonstrated through the blog system example. 5) Laravel provides powerful user authentication and authorization functions. 6) Debugging skills include using logging systems and Artisan tools. 7) Performance optimization suggestions include lazy loading and caching.

Laravel and the Full Stack: Front and Back TogetherLaravel and the Full Stack: Front and Back TogetherApr 18, 2025 am 12:07 AM

Laravel realizes full-stack development through the Blade template engine, EloquentORM, Artisan tools and LaravelMix: 1. Blade simplifies front-end development; 2. Eloquent simplifies database operations; 3. Artisan improves development efficiency; 4. LaravelMix manages front-end resources.

Laravel: A Framework for Modern Web DevelopmentLaravel: A Framework for Modern Web DevelopmentApr 18, 2025 am 12:05 AM

Laravel is a modern PHP-based framework that follows the MVC architecture model, provides rich tools and functions, and simplifies the web development process. 1) It contains EloquentORM for database interaction, 2) Artisan command line interface for fast code generation, 3) Blade template engine for efficient view development, 4) Powerful routing system for defining URL structure, 5) Authentication system for user management, 6) Event listening and broadcast for real-time functions, 7) Cache and queue systems for performance optimization, making it easier and more efficient to build and maintain modern web applications.

Laravel (PHP) vs. Python: Weighing the Pros and ConsLaravel (PHP) vs. Python: Weighing the Pros and ConsApr 17, 2025 am 12:18 AM

Laravel is suitable for building web applications quickly, while Python is suitable for a wider range of application scenarios. 1.Laravel provides EloquentORM, Blade template engine and Artisan tools to simplify web development. 2. Python is known for its dynamic types, rich standard library and third-party ecosystem, and is suitable for Web development, data science and other fields.

Laravel vs. Python: Comparing Frameworks and LibrariesLaravel vs. Python: Comparing Frameworks and LibrariesApr 17, 2025 am 12:16 AM

Laravel and Python each have their own advantages: Laravel is suitable for quickly building feature-rich web applications, and Python performs well in the fields of data science and general programming. 1.Laravel provides EloquentORM and Blade template engines, suitable for building modern web applications. 2. Python has a rich standard library and third-party library, and Django and Flask frameworks meet different development needs.

Laravel's Purpose: Building Robust and Elegant Web ApplicationsLaravel's Purpose: Building Robust and Elegant Web ApplicationsApr 17, 2025 am 12:13 AM

Laravel is worth choosing because it can make the code structure clear and the development process more artistic. 1) Laravel is based on PHP, follows the MVC architecture, and simplifies web development. 2) Its core functions such as EloquentORM, Artisan tools and Blade templates enhance the elegance and robustness of development. 3) Through routing, controllers, models and views, developers can efficiently build applications. 4) Advanced functions such as queue and event monitoring further improve application performance.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Have Crossplay?
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software