Okay, time for some real talk.
You miss out on the real power of your database.
Why? Because SQL is mysterious and you don’t know what it can do for you.
SQL is hard because it’s declarative, not imperative. You have to say “this is the result I want” instead of “follow these steps”. That makes it feel unfamiliar to most devs. And without experience, this unfamiliar approach makes SQL hard to write and reason about.
Writing SQL as a beginner is a mindfuck. Something you’d solve with a simple for loop can require mind-bending queries. Working primarily with columns of data instead of arrays of objects changes the way you need to think. You can’t just solve problems by adding more code.
Worse: there’s a performance penalty that gets applied if you phrase your request (“this is the result I want”) in the wrong way.
It’s not enough to know the syntax of SQL. Just like JS, PHP, Ruby and Python, the syntax is just the beginning. You need to understand the fundamentals, too.
Unfortunately, most of us (me included!) started off with ORMs or other database abstraction layers. You write models and the libraries handle the database and generate SQL for you.
But when things go wrong or you need more power, that makes the database and accompanying SQL even more indecipherable! We end up trying to learn SQL when we hit the limitations of our abstraction layer. Then we have to reason about the libraries and our database tables and our queries at the same time. But we didn’t even write the tables or queries to begin with!
No wonder we fear SQL.
Besides, so much about SQL and database performance is straight-up mysterious.
But this stuff can be taught and learned!
Nobody starts with a deep understanding of SQL, but you CAN acquire it. Understanding SQL will stop you from fearing it, and that will make you more productive in the future.
Why is knowing SQL so valuable? Once you get it, you can:
SQL is a multi-purpose tool with a ton of upside.
I learned all about SQL during my 7 years at Google. Now I want to teach it to the world.