Claude Code performance

N+1 Query Problem Causing Performance Degradation

Application performance degrades significantly after adding a feature that loads related data. Profiling shows massive number of database queries (1 main query + N queries for each result). Adding 50 users slows down response by seconds instead of milliseconds.

The feature works correctly but is fundamentally inefficient, querying the database hundreds or thousands of times for what should be a few queries.

Error Messages You Might See

Application timeout after adding feature Database connection pool exhausted 50+ SELECT queries logged for single request
Application timeout after adding featureDatabase connection pool exhausted50+ SELECT queries logged for single request

Common Causes

  1. Lazy loading relationship in loop: for (user in users) { user.profile.name } triggers query per user
  2. Separate query for each item instead of batch loading
  3. Eager loading not configured, falling back to lazy loading
  4. No database indexes on foreign keys causing full table scans
  5. JOINs not used despite being available, falling back to multiple queries

How to Fix It

Enable SQL query logging to see all queries. Count them: if 51+ for 50 items, you have N+1. Use eager loading (JOIN FETCH) or explicit batch loading. Add database indexes on foreign keys. Use query analysis tools (EXPLAIN PLAN) to see join strategies. Consider denormalization or caching for expensive relationships.

Real developers can help you.

Kingsley Omage Kingsley Omage Fullstack software engineer passionate about AI Agents, blockchain, LLMs. Simon A. Simon A. I'm a backend developer building APIs, emulators, and interactive game systems. Professionally, I've developed Java/Spring reporting solutions, managed relational and NoSQL databases, and implemented CI/CD workflows. Krishna Sai Kuncha Krishna Sai Kuncha Experienced Professional Full stack Developer with 8+ years of experience across react, python, js, ts, golang and react-native. Developed inhouse websearch tooling for AI before websearch was solved : ) zipking zipking I am a technologist and product builder dedicated to creating high-impact solutions at the intersection of AI and specialized markets. Currently, I am focused on PropScan (EstateGuard), an AI-driven SaaS platform tailored for the Japanese real estate industry, and exploring the potential of Archify. As an INFJ-T, I approach development with a "systems-thinking" mindset—balancing technical precision with a deep understanding of user needs. I particularly enjoy the challenge of architecting Vertical AI SaaS and optimizing Small Language Models (SLMs) to solve specific, real-world business problems. Whether I'm in a CTO-level leadership role or hands-on with the code, I thrive on building tools that turn complex data into actionable value. Mehdi Ben Haddou Mehdi Ben Haddou - Founder of Chessigma (1M+ users) & many small projects - ex Founding Engineer @Uplane (YC F25) - ex Software Engineer @Amazon and @Booking.com Matthew Butler Matthew Butler Systems Development Engineer @ Amazon Web Services Jared Hasson Jared Hasson Full time lead founding dev at a cyber security saas startup, with 10 yoe and a bachelor's in CS. Building & debugging software products is what I've spent my time on for forever Pratik Pratik SWE with 15+ years of experience building and maintaining web apps and extensive BE infrastructure Dor Yaloz Dor Yaloz SW engineer with 6+ years of experience, I worked with React/Node/Python did projects with React+Capacitor.js for ios Supabase expert Victor Denisov Victor Denisov Developer

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help

Frequently Asked Questions

How to detect N+1 problems?

Enable SQL query logging. For N items, you should see ~O(1) or O(log N) queries, not O(N). If query count = 1 + N, that's N+1 problem.

How to fix with JOINs?

Use JOIN FETCH in query: SELECT user FROM User user JOIN FETCH user.profile WHERE ... (fetches user and related profile in single query).

Should all relationships be eager loaded?

No. Load eagerly only if always used. For conditional access, use explicit loading or batch loading when needed.

Related Claude Code Issues

Can't fix it yourself?
Real developers can help.

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help