WeSearch

76 RLS policies rewritten in one migration: the auth.uid() init-plan trap in Supabase

·7 min read · 0 reactions · 0 comments · 12 views
#supabase#postgres#performance#webdev
76 RLS policies rewritten in one migration: the auth.uid() init-plan trap in Supabase
⚡ TL;DR · AI summary

A recent migration revealed that 76 RLS policies in Supabase were inefficiently using the auth.uid() function. This function was being called for each row, leading to performance issues as the data size increased. By wrapping the function in a subquery, the performance was significantly improved, allowing the function to be evaluated only once per query.

Key facts
Original article
DEV.to (Top)
Read full at DEV.to (Top) →
Opening excerpt (first ~120 words) tap to expand

try { if(localStorage) { let currentUser = localStorage.getItem('current_user'); if (currentUser) { currentUser = JSON.parse(currentUser); if (currentUser.id === 3896990) { document.getElementById('article-show-container').classList.add('current-user-is-article-author'); } } } } catch (e) { console.error(e); } Vadym Arnaut Posted on May 20 76 RLS policies rewritten in one migration: the auth.uid() init-plan trap in Supabase #supabase #postgres #performance #webdev TL;DR. If your Supabase RLS policies call auth.uid() directly inside USING(...) or WITH CHECK(...), Postgres re-evaluates the function once per row. Wrap it as (SELECT auth.uid()) and the planner hoists the call to a single init plan that runs once per query. Same logical query, different plan, different cost at scale.

Excerpt limited to ~120 words for fair-use compliance. The full article is at DEV.to (Top).

Anonymous · no account needed
Share 𝕏 Facebook Reddit LinkedIn Threads WhatsApp Bluesky Mastodon Email

Discussion

0 comments

More from DEV.to (Top)