Is Laravel Slow? Optimize Queries & Indexes for Maximum Performance
July 20, 2025A detailed, example-rich guide to avoid slowdowns in Laravel apps by optimizing data retrieval and employing indexing smartly.
1. 🧠 Fetch Only What You Need
Loading every column and row with DB::table('users')->get() can clog resources. Instead:
$users = DB::table('users')
->select('id', 'name', 'email')
->where('status', 'active')
->limit(50)
->get();
With Eloquent:
$users = User::select('id','name','email')
->where('status','active')
->take(50)
->get();
Why? Less memory, fewer bytes transferred, faster response times.
2. 🔑 Leverage Database Indexing
If filtering on columns like customer_id or status, adding indexes speeds up searches:
Schema::table('orders', function (Blueprint $table) {
$table->index('customer_id');
$table->index(['status', 'created_at']); // composite index
});
Run php artisan migrate to apply. Only add indexes where they help in WHERE, JOIN, or ORDER BY. Avoid over-indexing to prevent slow writes.
3. 🛠️ Profile and Debug Queries
During development:
DB::enableQueryLog();
// run query then:
dd(DB::getQueryLog());
Try tools like Laravel Debugbar or Telescope, or run raw SQL with EXPLAIN to verify index use:
EXPLAIN SELECT * FROM orders WHERE customer_id = 5;
4. ✅ Checklist for Fast Laravel Queries
- Select only fields you need (
select()). - Limit rows with
limit()ortake(). - Add proper indexes on WHERE/JOIN columns.
- Profile with Debugbar/Telescope.
- Avoid loading unused relationships (prevent N+1 queries).
5. ✨ Advanced Tips & Bonus Tricks
Eager vs Lazy Loading: Use with() to avoid N+1:
$posts = Post::with('comments')->get();
Chunking big datasets:
Post::chunk(100, function($posts) {
foreach ($posts as $post) {
// process...
}
});
Cache heavy queries:
$posts = Cache::remember('all_posts', 60, function() {
return Post::with('comments')->get();
});
Use raw SQL when needed:
$rows = DB::select('SELECT * FROM orders WHERE status = ?', ['active']);
Monitor: Log every query:
DB::listen(function($query){
Log::info("SQL: {$query->sql} - Bindings: " . implode(',', $query->bindings) . " - Time: {$query->time}ms");
});
6. 🚀 Scale & Optimize Further
- Enable
OPcachein PHP. - Use
php artisan config:cacheandroute:cache. - Pick fast cache stores (Redis, Memcached).
- Consider horizontal scaling (multiple servers).
- Profile regularly; optimize early and often.
By writing precise queries, indexing smartly, and profiling well, your Laravel app will stay fast and scalable. Performance starts at your queries.
Blog
Notifire + FCM with Laravel
Sep 13, 2025
If you want to send Push Notifications from your Laravel app to mobile or web clients, the fastest and simplest way is to use Notifire. It integrate...
React Labs: View Transitions & Activity
Jun 17, 2025
React Labs: View Transitions & Activity Published April 23, 2025 by Ricky Hanlon. React Labs is sharing two new experimental featu...
Analyze Laravel Projects with Introspect
Jul 01, 2025
Analyze Laravel Codebases with Laravel Introspect If you’re doing a complex refactor or building dev tools, Laravel Introspect helps you quer...
Mastering Async Iteration in JavaScript with Array.fromAsync()
Jul 27, 2025
🔍 What Exactly is Array.fromAsync()? Array.fromAsync() is a static method introduced in ES2024 as part of JavaScript's growing support for asynchr...
Top Laravel & PHP Updates for Cleaner, Faster Code
Aug 17, 2025
Laravel Global Scopes: Automatic Query Filtering Eloquent Importance: Enforce consistent filters across all model queries (e.g., Soft Del...
Laravel 12.18.0 Update
Jun 17, 2025
Laravel 12.18.0 Update The Laravel team released version 12.18.0 with several cool updates: String encrypt() & decrypt() helpers are...