Laravel: How to Use Cache With Pagination?

แชร์
ฝัง
  • เผยแพร่เมื่อ 23 ม.ค. 2025

ความคิดเห็น • 96

  • @jordy1814
    @jordy1814 2 ปีที่แล้ว +19

    When using redis or memcached, you can used tagged cache (they are like folders for cache). You can then just clear all the cache for the tag.

  • @francisalvinbarretto
    @francisalvinbarretto 2 ปีที่แล้ว +11

    depends which cache provider you’ll use but what I usually do with redis is use tags for this so I can clear the container.

  • @mahmoud-kassem
    @mahmoud-kassem 2 ปีที่แล้ว +1

    nice video, you can use tags to group cache keys, i.e. you can set key for each page and give them all one tag 'users', and you can use Cache::flush('users') to forget all users tag keys at one time.

  • @maazilyas7105
    @maazilyas7105 2 ปีที่แล้ว +3

    I love this video. It is exactly what I was looking for. Thanks a lot.
    Instead of defining guessing 100 pages for clearing cache. You can use something like :
    In the below command, 4 is the number of items displayed on the page.
    $NoOfItemsOnPage = 4;
    $pagesCount = ceil(count(User::all())/$NoOfItemsOnPage);
    for($i=1; $i

  • @infureal
    @infureal 2 ปีที่แล้ว +5

    You don't need to use loop for cleaning all cache. Just use cache tags.
    Cache::tags(['user-pagination'])->put('user-page-1', $data); // Adding
    Cache::tags(['user-pagination'])->flush(); // Removing

    • @pnoper
      @pnoper 2 ปีที่แล้ว +2

      Yes, but: "Cache tags are not supported when using the file, dynamodb, or database cache drivers."

  • @JimOHalloran
    @JimOHalloran 2 ปีที่แล้ว +2

    Having worked a lot with Magento before coming to Laravel, cache tags was was first thought. Magento's solution to cache back ends that don't support tags was to nuke the entire cache on those back ends. Brute force, but effective (if not very efficient).
    Another approach, depending on the size of the data set, might be to cache the entire record set, then apply the pagination after fetching from cache. Then you can use the same cache object for all requests, and paginate differently in the controller.
    Depending on the complexity of the presentation of the data, it might be more effective to query the data, and render the output, and cache the rendered output. If a significant amount of the request time comes from rendering the view (e.g. a heavy server side view), then just query caching might not yield significant improvement. A profiler or a tool like New Relic will help you dig into the execution time and determine whether that's the case.

  • @zouzouchak
    @zouzouchak 2 ปีที่แล้ว +10

    Hi Great Content , I think it will be a problem in your clearCache Observer ,if the user go from 1 to 3 and 4.... page not passing by 2 for example, it will not clear the cache of other pages only the first page because of the Break
    but its helps me anyway thank you

    • @renwar
      @renwar 2 ปีที่แล้ว +2

      Yeah, it should be chaned to "continue" instead of "break"

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว +5

      Mmm, great catch, agree.

    • @fernandolamas330
      @fernandolamas330 2 ปีที่แล้ว

      @@LaravelDaily or maybe remove the else statement?

  • @haroldsomehands4271
    @haroldsomehands4271 2 ปีที่แล้ว

    is caching specific to that single user sessionid? or the "key" in that cache still accessible to other users?

  • @abdonajjar2981
    @abdonajjar2981 2 ปีที่แล้ว +7

    Did you know that in ttl parameter in remember static function you could parse a carbon instance like Carbon::parse('20 seconds') instead of using calculation it would be more readable for humans :)

  • @mibrahim4245
    @mibrahim4245 2 ปีที่แล้ว

    Think you're the smartest in laravel 🌹 ...
    Can you explain further about the "observer" ? .. and why not a real life example about implementing the redis cache .. thanks in advance..

  • @leonardocitton4627
    @leonardocitton4627 2 ปีที่แล้ว

    Great tutorial Povilas, Thanks!

  • @vladimirf7365
    @vladimirf7365 2 ปีที่แล้ว +1

    Redis has Redisearch module with FILTER/SORT/LIMIT/OFFSET abilities for more advanced useage.

  • @pavankumar-cf4et
    @pavankumar-cf4et 9 หลายเดือนก่อน

    Sir how to connect Microsoft access database in my laravel app

  • @Arturs-d9e
    @Arturs-d9e ปีที่แล้ว

    Even though this video is old, what if we use scopeFilter and continue to use pagination?

  • @sergeylazarev485
    @sergeylazarev485 2 ปีที่แล้ว +2

    How to cache pagination if you have a complex table with 10+ filters and 5+ columns for sorting and 4-6 page-size options.
    In addition, data in table may have loads of foreign keys. I think it is bad solution to observe each of related models to only clear the cache.

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว +2

      I wouldn't use cache with so many variables of data

  • @cardboarddignity
    @cardboarddignity 2 ปีที่แล้ว +4

    Model observer is indeed a good example for updating cached data. But unfortunately caching won't work at all if you use datatables with search and sorting functions (I believe you use datatables as well in this example). There is an option for remote search and remote data processing is required if you have >30 entries for a table, that way you would only load 1 page at a time from the DB

    • @mityukov
      @mityukov 2 ปีที่แล้ว

      I think that the key like `"users-" . $queryString` might help here

  • @EL_PANDA_742
    @EL_PANDA_742 2 ปีที่แล้ว

    Sir,
    Have you ever tried spatie/laravel-backup ?
    I faced an issue when taking db backup ... something related to dump.
    Terminal: ( Command not found : sh: mysqldump: command not found )

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว +1

      You don't have mysqldump installed on your server

  • @badger1741
    @badger1741 2 ปีที่แล้ว +2

    To clean cache you can use wildcards "*" instead "for" loops atleast with redis

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว

      Yes, you can use Tags with Redis for this. But not everyone uses Redis for caching.

  • @esedark
    @esedark 2 ปีที่แล้ว +1

    Hey nice video! But you can use Tags in Cache, so you don't have to do a foreach.

  • @ilhampamungkas5716
    @ilhampamungkas5716 2 ปีที่แล้ว

    Sir . Can laravel make paginate with clear url ? 🙏

  • @liviuiurcu9709
    @liviuiurcu9709 2 ปีที่แล้ว +1

    Hallo. Great content. How about if we have front and back end in Laravel, in front user can Adding something (a CRUD for auth User's) but I have and a Admin. How to use the same Controller, or how to make something like this?

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว +2

      I would personally use separate controllers, because there's a big change that in the future functionality may be different.

    • @liviuiurcu9709
      @liviuiurcu9709 2 ปีที่แล้ว

      @@LaravelDaily ok thanks for quick answer. Great job by the way.

  • @glypher352
    @glypher352 2 ปีที่แล้ว +2

    i never like using an arbitrary number like 100 to set the page limits. you could make a function to query for count and divide by your pages and use that number for your upper page limit.

    • @mityukov
      @mityukov 2 ปีที่แล้ว

      I'm thinking about using cache tags for clearing all users-related at once

  • @kkamarada4
    @kkamarada4 2 ปีที่แล้ว +1

    I would use a cache tag, like "user-pages". So, I would just delete the cache by the assigned tag, when it's needed.

  • @darshasnparmar5558
    @darshasnparmar5558 2 ปีที่แล้ว

    Is laravel collection methods are slower than PHP array functions ?

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว

      Not really. At least not in a way that you would actually "feel" in reality.

  • @wildfireDZ
    @wildfireDZ 2 ปีที่แล้ว +1

    I use cache mainly for statistics and long queries instead of doing calculations for every request

  • @BlueJDev
    @BlueJDev 2 ปีที่แล้ว +1

    Also, wouldn't caching be pointless if your table has sortable columns?

  • @user-xv1pb1ge3y
    @user-xv1pb1ge3y 5 หลายเดือนก่อน

    you can use Illuminate\Support\Facades\Artisan;
    in the UserController/ update function
    Artisan::call('cache:clear');
    all cache cleared

  • @azaf
    @azaf 2 ปีที่แล้ว

    Hi, can you please do a video on configuring vite js, laravel, inertia and vue 3 running on homestead? I would greatly appreciate it.

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว +1

      I don't use homestead, I use Laravel valet, so I can't do a video you're asking for

    • @azaf
      @azaf 2 ปีที่แล้ว

      @@LaravelDaily I would greatly appreciate it 🙏🏼

    • @azaf
      @azaf 2 ปีที่แล้ว

      @@LaravelDaily I can't get my head around loading scss and js files with vite. Also, their documentation is not that good.

  • @GergelyCsermely
    @GergelyCsermely 2 ปีที่แล้ว

    Hi!
    Thanks. My qiuestion would be, is there a solution to clear cache like files with asterix? like users-* eg. thanks

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว

      You can use Tags for this, but it's supported properly only by Redis and Memcached drivers, from what I remember.

  • @MrKataklysm
    @MrKataklysm 2 ปีที่แล้ว

    What do you think about using cache in cases when you are using front-end pagination, like jQuery Datatable for instance?

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว

      I don't think caching makes sense in that case

    • @MrKataklysm
      @MrKataklysm 2 ปีที่แล้ว

      @@LaravelDaily Thanks for your answer! How could I make site loading faster in this case? Passing Model::all() to the view where the Datatable creates pagination can slow down loading time a little bit when dealing with lots of records. Is there any way to deal with this without any serious hacking/reworking?

    • @aculz
      @aculz 2 ปีที่แล้ว +2

      @@MrKataklysm if you have big data with a relationship, using an eloquent eagerload maybe is the problem you get slower. i'd prefer you may use query builder of join to handle this, in my experience, it will run more faster. and dont forget to Index your column to make it more faster
      im running with datatables, which load at least minimun 100K data, and its cost me 1-2sec to load the datatables serverside

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว +1

      Use server side rendering of datatables, which would load only one page of data

    • @MrKataklysm
      @MrKataklysm 2 ปีที่แล้ว

      @@LaravelDaily Thanks for the answers! I'll give it a try.

  • @peterf983
    @peterf983 ปีที่แล้ว

    Great! Now I must check if it works with Sqlsrv 2008 R2 as altervative to DataTables.

  • @nuhelsyed7995
    @nuhelsyed7995 2 ปีที่แล้ว +1

    There will be another issue if i change per page size.

  • @uit92
    @uit92 2 ปีที่แล้ว

    Great video! Thank you a lot. Could you do a video about practice example when using queue with "WithoutOverlapping", "ShouldBeUnique" feature in Lavavel? Therefore, we can understand the benefit when using these features in real cases.

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว +1

      Those are pretty niche cases, not sure if it would be interested for masses on my channel. But will add to the extended to-do list under "maybe".

  • @khizer3528
    @khizer3528 2 ปีที่แล้ว

    Real life cases wow 🔥

  • @OnlinePseudonym
    @OnlinePseudonym 2 ปีที่แล้ว +4

    measure, then cache what's slow and important. Premature optimization is the root of all evil. If you implement a caching strategy for paginated records, I think the strong implication is that you're not too concerned about record ordering on pages. I would advise against caching this particular type of data. There's a vanishingly small - if any - performance gain to be had, at the expense of record page ordering inconsistencies.

  • @ifeoluwaAlao
    @ifeoluwaAlao 2 ปีที่แล้ว

    how about you help with a video to paginate but in a random order , cause anytime I query in a random order , and paginate it , I get duplicates from page to page

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว

      To me, randomizing the data and then paginating it doesn't make much sense. In what real-life scenario you would actually need this?

    • @ifeoluwaAlao
      @ifeoluwaAlao 2 ปีที่แล้ว

      @@LaravelDaily I'm building a startup yeah? and I intend to infuse machine learning as time goes on , but everytime the user opens the app, I don't want them to see the same content they saw on their last session especially when new content hasn't been added and while I still try to make machine learning do this I wanted to give the impression that it already exist ,
      so everytime you open the app , the content is shuffled , and the user keeps staying interested and seeing something new everytime

    • @genechristiansomoza4931
      @genechristiansomoza4931 2 ปีที่แล้ว

      @@ifeoluwaAlao You don't cache random things.

    • @ifeoluwaAlao
      @ifeoluwaAlao 2 ปีที่แล้ว

      @@genechristiansomoza4931 it's not about cache ,it's just normal query from eloquent

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว

      Hmm, reminds me of how Facebook/Twitter show us the personalized data every time we load their homepage, so maybe it is a realistic scenario after all. Well, in this case, there's no other way I would think of than caching that randomized data specifically for one user for one session.

  • @fcolecumberri
    @fcolecumberri 2 ปีที่แล้ว +1

    I sometimes prefer to tweak the DB cache/buffer configurations since those are typically configured by default to very small systems so once you tell the DB it can use more ram the performance sometimes might improve. I know that this still makes the DB call, but still I can see how the 2nd call for the same table is always faster. Also the DB cache implementation is better that whatever I can implement on Laravel since updates on DB cache are also reflected on the cache. IMHO Laravel cache is only better on stuff that need to be calculated (not just read).

  • @tomaserlebach9760
    @tomaserlebach9760 2 ปีที่แล้ว

    A quite general question: How do you handle caches during development?
    I didn't found a good way yet to disable them entirely during development.

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว +2

      In .env file use CACHE_DRIVER=null

    • @tomaserlebach9760
      @tomaserlebach9760 2 ปีที่แล้ว

      @@LaravelDaily I tried that in the past and that didn't worked. Maybe I did something wrong. I will give it another shot. Thanks a lot! :)

    • @alexaverkiyev9099
      @alexaverkiyev9099 2 ปีที่แล้ว

      Null object patern works always with no matter what. In this case with Cache driver it will work. But I believe it comes straight from the box

  • @cardboarddignity
    @cardboarddignity 2 ปีที่แล้ว

    Povilas, you should do video about Elastic search integratikn to Laravel. Or basically any other fulltext search index engine

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว +1

      It's all in Laravel Scout docs, then 90% of the video would be installing the Elasticsearch or Meilisearch or Algolia. Which is in their docs, again. Not worth the video, in my opinion.

    • @cardboarddignity
      @cardboarddignity 2 ปีที่แล้ว

      Okay, maybe you're right

  • @MartinBojmaliev
    @MartinBojmaliev 2 ปีที่แล้ว +2

    I think it's good idea if Laravel had something like Cache::startsWith('user-page-')->forget(); Otherwise you won't be able to clear the cache properly

    • @quocminhvu2951
      @quocminhvu2951 2 ปีที่แล้ว

      It has 'Cache::tags' if you use Redis or Memcached driver

  • @ward7576
    @ward7576 2 ปีที่แล้ว +5

    Unless you would use Collection pagination instead of DB pagination, you would lose the benefit of caching once you do any sorting/filtering... or make it unnecessarily tough.

  • @SanderCokart
    @SanderCokart 2 ปีที่แล้ว

    Must validate the page number

  • @codingtodecode
    @codingtodecode 2 ปีที่แล้ว

    Suggestion :: requirement
    How to use redis and database together in controller

  • @syedanwar1872
    @syedanwar1872 2 ปีที่แล้ว

    Wow sir

  • @DiscoverPakistanShorts
    @DiscoverPakistanShorts ปีที่แล้ว

    how to use other modal relation with cache ?
    just like that
    Cache::remember('chirps', now()->addMinutes(1), function () {
    return Chirp::with('user')->latest()->get();
    });

  • @SaiyanJin85
    @SaiyanJin85 2 ปีที่แล้ว

    Caching the pagination usually means something is wrong with the way we load the data like unoptimised queries, lack of indeces etc. Also caching pagination is kinda pointless since 90% times the data will change relatively often so clear the cache all the time beats the initial purpose of caching.

  • @bariqdharmawan4680
    @bariqdharmawan4680 2 ปีที่แล้ว +1

    Yap I'm agree with you, it's a lot of risk if we're using cache in pagination. But maybe the person who ask this, have an example of using pagination in a content that have low of possibility to change. For example, a list of some "big client" in your company profile. The list have 10 data, and you want to paginate it 3 data each page

  • @motomono
    @motomono 2 ปีที่แล้ว

    Even more interesting problem is - how to use cache with random()

    • @LaravelDaily
      @LaravelDaily  2 ปีที่แล้ว +3

      A bigger question is WHY would you do that.

    • @motomono
      @motomono 2 ปีที่แล้ว

      @@LaravelDaily Why we use cache? We use cache to ease DB workload and speed-up the system response, don't we? So in my case I want to show people products in random order so every product has it's chance to be seen. The question is is it worth the effort.

    • @Remls
      @Remls 2 ปีที่แล้ว

      @@motomono
      You could choose to call Products::inRandomOrder()->... and then cache the results of that for, let's say, 5 mins.
      Pro: You will only call the database once every 5 minutes.
      Con: Every user will see the same results for those 5 minutes. Don't know how much of a problem that is for you. You can reduce TTL, or cache more records and then display those randomly.

    • @motomono
      @motomono 2 ปีที่แล้ว

      @@Remls Hi mate, tank you for the response. Unfortunately this approach doesn't work well with pagination - the problem is that on every page the user will see freshly randomized products so everytime the user get's back to let's say page no. 2 the products sowed on this page will be different. We want to randomize the product set once, then paginate them so te client can walk through tha pages and go back to the page x and see the same what he left.

    • @Remls
      @Remls 2 ปีที่แล้ว

      @@motomono
      Maybe store randomised list of all IDs in cache, and then call find() on a slice of that array based on what page the user wants?
      You can cache the pages as well if you wish (but discard the cached pages if the cached list of IDs has expired).

  • @Flankymanga
    @Flankymanga 2 ปีที่แล้ว

    Guys is it just me or does somebody else also see that paginating using OFFSET is a very bad habbit?

  • @shahramakbari6082
    @shahramakbari6082 2 ปีที่แล้ว

    According your video pagination is not a good idea and we can solve slow pagination with other solutions.
    In the other hand for caching and clearing a lot of data we can use cache tags or redis array key or wildcard key and...
    So foreach is not a good way