cari
Rumahrangka kerja phpLaravel使用chunkById方法时请不要进行排序!

下面由Laravel教程栏目给大家介绍使用chunkById方法时请不要进行排序!,希望对需要的朋友有所帮助!

使用chunkById方法时请不要进行排序!

使用 chunkById 方法的时候请不要进行排序

最近在做开发任务的时候碰到了个诡异的问题,于是分享给大家

问题说明

由于需要批量处理数据,并且这个数据的量很大,一次全部取出然后执行是不现实的,幸运的是 Laravel 为我们提供了 chunkById 方法来让我们方便的处理。伪代码如下

Student::query()
    ->where('is_delete', false)
    ->orderBy('id', 'DESC')
    ->chunkById(200, function($students) {
            // 在这里进行逻辑处理
    });

咋一眼看上去,并没有什么问题,但是实际执行代码的时候会发现 chunkById 只会执行第一次,第二次以后由于某种原因会停止执行。

查找原因

Laravel 的源码中 chunkById 代码如下

  public function chunkById($count, callable $callback, $column = null, $alias = null)
    {
        $column = is_null($column) ? $this->getModel()->getKeyName() : $column;
        $alias = is_null($alias) ? $column : $alias;
        $lastId = null;
        do {
            $clone = clone $this;
            $results = $clone->forPageAfterId($count, $lastId, $column)->get();
            $countResults = $results->count();
            if ($countResults == 0) {
                break;
            }
            if ($callback($results) === false) {
                return false;
            }
            $lastId = $results->last()->{$alias};
            unset($results);
        } while ($countResults == $count);
        return true;
    }

看起来没什么问题,由于 while 循环是根据 $countResults == $count 来判断的,那么我们 dump 一下这两个变量就会发现, 第一次这两个是一致的,第二次由于数据不一致导致程序停止。

在上面的代码中, $count 是由 $results = $clone->forPageAfterId($count, $lastId, $column)->get(); 来获得的,

继续查看 forPageAfterId 方法

public function forPageAfterId($perPage = 15, $lastId = 0, $column = 'id')
{
    $this->orders = $this->removeExistingOrdersFor($column);
    if (! is_null($lastId)) {
        $this->where($column, '>', $lastId);
    }
    return $this->orderBy($column, 'asc')
                ->take($perPage);
}

我们可以看到,在这里返回的结果是 orderBy 进行升序排列的, 而我们的原始代码是进行降序排列,就会导致 count 不一致,从而使 chunkById 结束执行。

解决方案

把之前的 orderBy('id', 'desc') 移除即可。

Student::query()
    ->where('is_delete', false)
    ->chunkById(200, function($students) {
            // 在这里进行逻辑处理
    });

总结

  • 以后使用 chunkById 或者 chunk 方法的时候不要添加自定义的排序

  • 骚到老,学到老。。。

Atas ialah kandungan terperinci 使用chunkById方法时请不要进行排序!. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Artikel ini dikembalikan pada:learnku. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
Ilusi kemasukan: menangani pengasingan dan kesepian dalam kerja terpencilIlusi kemasukan: menangani pengasingan dan kesepian dalam kerja terpencilApr 25, 2025 am 12:28 AM

Tocombatisolationandlonelinessinremotework, companesshouldimplementregular, articlefulinteractions, provideequalgrowthopposities, andusetechnologyefectively.1) FostergenuineconnectionnectionThoughvoughvirtualcoffeebreaksandpersonalusharing.2) Ensureremorsharing

Laravel untuk pembangunan penuh: panduan komprehensifLaravel untuk pembangunan penuh: panduan komprehensifApr 25, 2025 am 12:27 AM

Laravelispopularforfull-stackdevelopmentbeCausofersaseamlessblendofbackendpowerandfrontendflexibility.1) ITSBackendCapabilities, likeeloquentorm, SimplifyDatabaseIntions.2) thebladetemplatingengineAllowsforclean, dynamichtmltes.3)

Pertunjukan Persidangan Video: Memilih platform yang sesuai untuk mesyuarat jauhPertunjukan Persidangan Video: Memilih platform yang sesuai untuk mesyuarat jauhApr 25, 2025 am 12:26 AM

Faktor utama dalam memilih platform persidangan video termasuk antara muka pengguna, keselamatan, dan fungsi. 1) Antara muka pengguna harus intuitif, seperti zoom. 2) Keselamatan perlu diberi perhatian, dan pasukan Microsoft menyediakan penyulitan akhir-ke-akhir. 3) Fungsi perlu memadankan keperluan, GoogLemeet sesuai untuk mesyuarat pendek, dan Ciscowebex menyediakan alat kerjasama lanjutan.

Apa versi pangkalan data yang serasi dengan Laravel terkini?Apa versi pangkalan data yang serasi dengan Laravel terkini?Apr 25, 2025 am 12:25 AM

Versi terbaru Laravel10 bersesuaian dengan MySQL 5.7 dan ke atas, PostgreSQL 9.6 dan ke atas, SQLite 3.8.8 dan ke atas, SQLServer 2017 dan ke atas. Versi ini dipilih kerana mereka menyokong ciri -ciri ORM Laravel, seperti jenis data JSON MySQL5.7, yang meningkatkan kecekapan pertanyaan dan penyimpanan.

Faedah menggunakan Laravel sebagai rangka kerja penuhFaedah menggunakan Laravel sebagai rangka kerja penuhApr 25, 2025 am 12:24 AM

LaravelisanexcellentchoiceForfull-stackdevelopmentduetoitsrobustfeaturesandeaseofuse.1) ITSimplifiesComplexTasksWithitsModernphpsyntaxandtoolslikeForForForForForForForForForForForForForForForForForForForForForForForfront-Endandeloquentormforback-end.2)

Apakah versi terbaru Laravel?Apakah versi terbaru Laravel?Apr 24, 2025 pm 05:17 PM

Laravel10, ReleaseonFebruary7,2023, isTheLatestVersion.Itfeatures: 1) InbrovedErrorHandlingWithanewreportmethodintheThexceptionHandler, 2) EnhancedSupportforphp8.1FeatureSlikeenums, dan3-laravelplackorinterforinterforinterplackshipshipforinter.

Bagaimanakah versi Laravel terbaru memudahkan pembangunan?Bagaimanakah versi Laravel terbaru memudahkan pembangunan?Apr 24, 2025 pm 05:01 PM

Thelatestlaravelversionenhancesdevelopmentwith: 1) SimplifiedRoutingingingSingModelbinding, 2) EnhancedEloquentCapabilitiesWitHnewQueryMethods, and3) InfrovedSupportFormodernPhpfeatureSlikenamedArguments.

Di mana saya boleh mendapatkan nota pelepasan untuk versi Laravel terkini?Di mana saya boleh mendapatkan nota pelepasan untuk versi Laravel terkini?Apr 24, 2025 pm 04:53 PM

Anda boleh mencari nota pelepasan untuk versi Laravel terkini di laravel.com/docs. 1) Nota pelepasan memberikan maklumat terperinci mengenai ciri -ciri baru, pembetulan pepijat dan penambahbaikan. 2) Mereka mengandungi contoh dan penjelasan untuk membantu memahami penerapan ciri -ciri baru. 3) Perhatikan potensi kerumitan dan isu keserasian ke belakang ciri -ciri baru. 4) Kajian semula nota pelepasan boleh memastikan ia dikemas kini dan memberi inspirasi kepada inovasi.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma