[{"data":1,"prerenderedAt":98},["ShallowReactive",2],{"post-011-postgres-only-en":3,"post-og-011-postgres-only":69},{"id":4,"title":5,"bars":6,"blurb":7,"body":8,"color":6,"contacts":6,"date":52,"dateModified":6,"description":53,"extension":54,"featured":55,"groups":6,"kicker":56,"meta":57,"metrics":6,"n":58,"navigation":59,"openTabs":6,"path":60,"progress":6,"readTime":61,"reading":6,"role":6,"rules":6,"running":6,"seo":62,"ships":6,"slug":63,"stack":6,"started":6,"status":6,"stem":64,"streak":6,"tag":65,"tagColor":67,"tagline":6,"tasks":6,"timeline":6,"topics":6,"week":6,"year":6,"__hash__":68},"en\u002Fwriting\u002F011-postgres-only.md","The weird joys of a postgres-only backend",null,"What happens when you refuse to add a second database for five years.",{"type":9,"value":10,"toc":46},"minimark",[11,15,19,24,27,43],[12,13,14],"p",{},"№ 011 · mar 06 '26 · 6 min · stack",[16,17,5],"h2",{"id":18},"the-weird-joys-of-a-postgres-only-backend",[12,20,21],{},[22,23,7],"em",{},[25,26],"hr",{},[12,28,29,30,34,35,38,39,42],{},"the rule is simple: if postgres can do it, postgres does it. jobs queue? ",[31,32,33],"code",{},"SELECT ... FOR UPDATE SKIP LOCKED",". full-text search? ",[31,36,37],{},"tsvector",". vector search? ",[31,40,41],{},"pg_vector",". caching? materialised views and a cron. feature flags? a table.",[12,44,45],{},"it sounds austere. it is. it's also five years of fewer moving parts, one backup story, one monitoring dashboard, one mental model. the day i have to add redis, i'll write a sad notebook about it. that day hasn't arrived.",{"title":47,"searchDepth":48,"depth":49,"links":50},"",2,3,[51],{"id":18,"depth":48,"text":5},"2026-03-06","The weird joys of a postgres-only backend — what happens when you refuse to add a second database for five years.","md",false,"stack",{},"011",true,"\u002Fwriting\u002F011-postgres-only","6 min",{"title":5,"description":53},"011-postgres-only","writing\u002F011-postgres-only",{"label":66,"color":67},"technical","var(--green)","ioFpcUHUP-H3rf1rNmQLtGPmDcC7-QDARw3pxQ7o0mU",{"id":4,"title":5,"bars":6,"blurb":7,"body":70,"color":6,"contacts":6,"date":52,"dateModified":6,"description":53,"extension":54,"featured":55,"groups":6,"kicker":56,"meta":95,"metrics":6,"n":58,"navigation":59,"openTabs":6,"path":60,"progress":6,"readTime":61,"reading":6,"role":6,"rules":6,"running":6,"seo":96,"ships":6,"slug":63,"stack":6,"started":6,"status":6,"stem":64,"streak":6,"tag":97,"tagColor":67,"tagline":6,"tasks":6,"timeline":6,"topics":6,"week":6,"year":6,"__hash__":68},{"type":9,"value":71,"toc":92},[72,74,76,80,82,90],[12,73,14],{},[16,75,5],{"id":18},[12,77,78],{},[22,79,7],{},[25,81],{},[12,83,29,84,34,86,38,88,42],{},[31,85,33],{},[31,87,37],{},[31,89,41],{},[12,91,45],{},{"title":47,"searchDepth":48,"depth":49,"links":93},[94],{"id":18,"depth":48,"text":5},{},{"title":5,"description":53},{"label":66,"color":67},1777071043797]