Two Wonderful Investments In Your Programming Career


We invest a lot of our time learning programming languages and frameworks, but I think it's just as important to learn the "foundational" skills of our industry, including:

  • Patterns and Principles
  • Architectural Styles
  • Object-oriented as well as Functional
  • Your editor
  • SQL

I think most people absorb the first two as their career progresses, and some might dabble in the third. But how many of us take the time to learn SQL or an editing skill like Vim?

SQL: The Gift That Keeps Giving

Whenever I suggest people learn SQL, the pushback I get is that "SQL sucks", it's old, and not good for many tasks. This tells me that I should do a better job positioning my suggestion.

I've long held that your application exists to do one thing: produce happy customers which, in turn, produces wonderful data. Your company relies on this data to know if you and your application actually work as intended. Often, it's up to you to collect this data.

When you learn SQL, you learn how a database works internally (if you're using a relational system). How data is stored, protected, and what guarantees are in place to make sure you're not generating crap.

I learned SQL back in 1993 and it was, and still is, the best investment I've ever made in my career. I use SQL on a weekly basis to do all kinds of things, like figure out what kind of video production I want to make next (I'm thinking something about GitHub).

You can learn SQL in a weekend, it's so simple, and so powerful!

Vim, My Old Friend

I dedicated 2 weeks to training my fingers to use Vim, back in 2008. I was building a Rails application and I took the time to watch a PeepCode video (Smash Into Vim, which is now at Pluralsight) and practice on the job. I went slowly at first, but then...

I'll never forget a friend watching me code one day, muttering to himself "I should learn Vim someday". I didn't think I was moving all that quickly, but after switching screens and watching him code... it was like watching grass grow.

Vim has come and gone for me over the years as I moved to various IDEs, like WebStorm, RubyMine, TextMate, and eventually VS Code. I had reasons for moving to each one, but every now and again I pop into Vim just to remind myself how good it is.

And then I found the NeoVim bindings for VS Code. Full disclosure: I work with the VS Code team at Microsoft, making videos and extensions. Last week we were talking about the NeoVim extension which embeds a full version of NeoVim directly! It basically turns the VS Code editing experience into a Vim experience.

I like VS Code, a lot. I like the extensions, the shortcuts, and the overall look and feel. I've been using it for the last 9 years and loving it. I tried to plug in the Vim bindings previously, but always felt frustration.

The NeoVim extension changed all that. I goofed around with it for a few hours, and within minutes my fingers were falling into the old patterns - but I was using VS Code! It was a very happy moment - so much so that I made a video for it!

It's pretty wild how, after all these years, I can fall back into Vim and be so, so productive once again. It's also weird how I haven't aged a bit!

What are your favorite investments? Let me know!

P.S. Would you be interested in a video production like "The GitHub Pro"? My idea is to show how to use GitHub for personal (building your profile, a good issue and PR), professional (creating a project, locking things down, issue and discussion templates), organizational (GitHub Flow, Trunk-based, branch policy) and devops (actions, build, etc).

Thanks again for reading!

Rob

🥷🏽 Notes From an Imposter Programmer

I taught myself to code in 1998 and within 7 years had a client list that included Google, Microsoft, Starbucks, Ameritech, KLA-Tencor, PayPal, and Visa. In 2014 I decided that I really needed to understand core Computer Science concepts, so I dove in, using the free resources from MIT and Stanford. In 2016 I shared what I learned with The Imposter's Handbook.

Read more from 🥷🏽 Notes From an Imposter Programmer

Full disclosure: I work at Microsoft but what you're about to read is 100% my personal opinion. Don't @ me with "dude from Microsoft claims..." please... I've been deep in a rewrite of the AI chapter in The Imposter's Roadmap, and I'm trying to discuss the role of AI in a senior programmer's life... and I noticed something interesting as the AI discussions heat up in our industry: we both fear and want to protect junior developers. What a weird straw man argument! Note: this article addresses...

I learned to play ice hockey when I was 11 and, as a kid from Southern California, it wasn't easy. I learned how to skate and how to play the game at the same time, all while going through a massive growth spurt. My sister once called me a "baby giraffe on a frozen lake". Nice. One of the hardest things to learn when it comes to skating is the "hockey turn", which looks something like this: Photo Credit: Tim Bates/OJHL Images This is hard. Very hard. If you master it, you can change direction...

I make videos for a living and I swear: each one is an adventure. You would think I would have a system down by now but, as it turns out, each video is a unique thing that demands it's own type of story telling. For instance: here's the latest video I did for the VS Code team. It's on Remote Development with VS Code, which is wild stuff! Many call it the "killer feature", but that brings up an interesting problem: how do you make a video about an 'interesting feature'? We discussed this...