Tôi hoàn toàn không đồng ý với những người nói sử dụng NULL vô điều kiện. Cho phép một cột là NULL giới thiệu một trạng thái bổ sung mà bạn sẽ không có nếu bạn thiết lập cột là NOT NULL. Không làm điều này nếu bạn không cần trạng thái bổ sung. Có nghĩa là, nếu bạn không thể tìm ra sự khác biệt giữa ý nghĩa của chuỗi rỗng và ý nghĩa của null, thì hãy thiết lập cột là NOT NULL và sử dụng chuỗi rỗng để biểu diễn trống. Trình bày cùng một thứ theo hai cách khác nhau là một ý tưởng tồi.
Hầu hết những người nói với bạn sử dụng NULL cũng đưa ra một ví dụ trong đó NULL có nghĩa là một cái gì đó khác với chuỗi rỗng. Và trong những ví dụ đó, họ đúng.
Tuy nhiên, hầu hết thời gian, NULL là một trạng thái bổ sung không cần thiết chỉ buộc các lập trình viên phải xử lý nhiều trường hợp hơn. Như những người khác đã đề cập, Oracle không cho phép trạng thái bổ sung này tồn tại bởi vì nó xử lý NULL và chuỗi rỗng như nhau (không thể lưu trữ một chuỗi rỗng trong một cột không cho phép null trong Oracle).