SQL NULLs are Weird!

submited by
Style Pass
2025-01-09 13:30:04

Yes, you read that right. SQL does treat all NULL values differently. I learnt this a while back while working on Convoy and again on LiteQueue: a Golang a queueing library.

Basically, any column with a UNIQUE constraint can have multiple NULL values, because each NULL value is a distinct value that is different from other NULLs, and this is even less obvious if you’re used to using ORMs. I tested this with SQLite, Postgres and MYSQL and they all behave like this. Let’s prove this with some examples

First, let’s establish a baseline to further highlight how this can be confusing. We’ll be comparing different values using the logical equals (“=”) operator and, even with basic programming experience, the results might not be what you expect:

select null = null; returns NULL, because each NULL is basically a placeholder representing any “unknown value”. Two unknown values are not necessarily the same value; we can’t say that they are equal, because we don’t know the value of either of them. So it evaluates to an “unknown value” that’s obviously not “true” or “false”, which is why NULL = NULL returns NULL. Very weird, ikr! So now we’ve established that two NULL values in the same column are not considered equal using “=”; but we can use IS, because the IS operator checks for identity or rather if the type of both values are, well, NULL.

Leave a Comment