Bird
Raised Fist0
Spring Bootframework~3 mins

Why @NotNull, @NotBlank, @NotEmpty in Spring Boot? - Purpose & Use Cases

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
The Big Idea

Discover how simple annotations can save you from endless input-checking headaches!

The Scenario

Imagine you have a form where users enter their name and email. You check each input manually in your code to make sure they are not empty or null before saving.

The Problem

Manually checking each input is slow and easy to forget. You might miss a check, causing errors or bad data in your app. It makes your code messy and hard to maintain.

The Solution

Using @NotNull, @NotBlank, and @NotEmpty annotations automatically validates inputs before your code runs. This keeps your code clean and safe.

Before vs After
Before
if (name == null || name.trim().isEmpty()) { throw new Exception("Name required"); }
After
@NotBlank
private String name;
What It Enables

It enables automatic, clear, and reusable input validation that prevents bad data and reduces bugs.

Real Life Example

When users register on a website, these annotations ensure their username and password fields are filled correctly before saving to the database.

Key Takeaways

Manual input checks are error-prone and clutter code.

Annotations like @NotNull, @NotBlank, and @NotEmpty automate validation.

This leads to cleaner, safer, and easier-to-maintain code.

Practice

(1/5)
1. Which annotation ensures a string field in a Spring Boot application is not null, but allows empty strings?
easy
A. @NotEmpty
B. @NotBlank
C. @NotNull
D. @Valid

Solution

  1. Step 1: Understand @NotNull behavior

    @NotNull only prevents the value from being null but allows empty strings or collections.
  2. Step 2: Compare with other annotations

    @NotEmpty and @NotBlank prevent empty values, so they are stricter than @NotNull.
  3. Final Answer:

    @NotNull -> Option C
  4. Quick Check:

    @NotNull allows empty but not null [OK]
Hint: Remember: @NotNull forbids null, allows empty [OK]
Common Mistakes:
  • Confusing @NotNull with @NotEmpty or @NotBlank
  • Thinking @NotNull forbids empty strings
  • Assuming @Valid checks null automatically
2. Which of the following is the correct way to annotate a string field that must not be null, empty, or only spaces in Spring Boot?
easy
A. @NotBlank private String name;
B. @NotEmpty private String name;
C. @NotNull @NotEmpty private String name;
D. @NotNull private String name;

Solution

  1. Step 1: Identify annotation that forbids null, empty, and spaces

    @NotBlank ensures the string is not null, not empty, and not just whitespace.
  2. Step 2: Check other options

    @NotNull allows empty or spaces; @NotEmpty forbids empty but allows spaces; only @NotBlank covers all three.
  3. Final Answer:

    @NotBlank private String name; -> Option A
  4. Quick Check:

    @NotBlank forbids null, empty, spaces [OK]
Hint: Use @NotBlank for strings with no spaces or empties [OK]
Common Mistakes:
  • Using @NotEmpty but ignoring spaces
  • Combining @NotNull and @NotEmpty unnecessarily
  • Assuming @NotNull forbids empty strings
3. Given the code snippet:
@NotEmpty
private List<String> tags;

What happens if tags is set to an empty list during validation?
medium
A. Validation passes because list is not null
B. Validation fails because list is empty
C. Validation fails only if list is null
D. Validation passes regardless of list content

Solution

  1. Step 1: Understand @NotEmpty on collections

    @NotEmpty forbids null or empty collections, so empty list fails validation.
  2. Step 2: Compare with other annotations

    @NotNull allows empty list; @NotEmpty forbids empty; @NotBlank is for strings only.
  3. Final Answer:

    Validation fails because list is empty -> Option B
  4. Quick Check:

    @NotEmpty forbids empty collections [OK]
Hint: @NotEmpty forbids empty lists or strings [OK]
Common Mistakes:
  • Thinking empty list passes @NotEmpty
  • Confusing @NotEmpty with @NotNull
  • Applying @NotBlank to collections
4. Consider this code snippet:
@NotBlank
private String title;

Which of the following values for title will cause validation to fail with @NotBlank but pass with @NotEmpty?
medium
A. " " (string with spaces only)
B. "Hello"
C. "" (empty string)
D. null

Solution

  1. Step 1: Understand @NotBlank validation rules

    @NotBlank forbids null, empty, and strings with only whitespace.
  2. Step 2: Analyze each value

    null and "" fail both @NotBlank and @NotEmpty; "Hello" passes both; " " passes @NotEmpty (length > 0) but fails @NotBlank (trimmed length = 0).
  3. Final Answer:

    " " (string with spaces only) -> Option A
  4. Quick Check:

    @NotBlank forbids spaces-only strings [OK]
Hint: @NotBlank forbids spaces-only strings [OK]
Common Mistakes:
  • Assuming empty string passes @NotBlank
  • Confusing @NotBlank with @NotEmpty
  • Ignoring spaces-only strings as invalid
5. You want to validate a user input field description that must not be null, empty, or only spaces, but also must allow strings like "0" or "false". Which annotation should you use in Spring Boot?
hard
A. @Size(min=1)
B. @NotEmpty
C. @NotNull
D. @NotBlank

Solution

  1. Step 1: Understand requirements for description

    Must not be null, empty, or spaces-only, but allow "0" or "false" strings.
  2. Step 2: Match annotation behavior

    @NotBlank forbids null, empty, and spaces-only strings but allows "0" and "false" as they are non-blank strings.
  3. Step 3: Check alternatives

    @NotNull allows empty; @NotEmpty forbids empty but allows spaces; @Size(min=1) forbids empty but not spaces-only.
  4. Final Answer:

    @NotBlank -> Option D
  5. Quick Check:

    @NotBlank fits all conditions [OK]
Hint: Use @NotBlank to forbid null, empty, and spaces-only [OK]
Common Mistakes:
  • Using @NotEmpty and missing spaces-only strings
  • Assuming @Size(min=1) forbids spaces-only
  • Confusing @NotNull with stricter annotations