Skip to content

Bits of .NET

Daily micro-tips for C#, SQL, performance, and scalable backend engineering.

  • Asp.Net Core
  • C#
  • SQL
  • JavaScript
  • CSS
  • About
  • ErcanOPAK.com
  • No Access
  • Privacy Policy
SQL

Add Constraint to SQL Table to ensure email contains @

- 11.06.18 | 24.03.26 - ErcanOPAK

The Strategy: Never trust your data source blindly. While frontend validation is great for UX, Database Constraints are your last line of defense. By adding a CHECK CONSTRAINT, you ensure that no invalid email address ever touches your storage, whether it comes from an API, a bulk import, or a manual script.

The Goal: To ensure the Email column always contains at least an @ symbol and follows a basic structure.


Option 1: The Simple “@” Check

If you only want to ensure the presence of the @ symbol (and allow NULLs if the column isn’t mandatory), this is the fastest and most efficient way:

-- Ensure '@' exists or the value is NULL
ALTER TABLE Users
ADD CONSTRAINT chk_email_basic 
CHECK (CHARINDEX('@', Email) > 0 OR Email IS NULL);

Option 2: The “Pattern Match” (More Robust)

Want to go a step further? You can use the LIKE operator with wildcards to ensure the email looks like a real address (e.g., something before the @, something after it, and a dot):

-- Ensures format like: x@x.x
ALTER TABLE Users
ADD CONSTRAINT chk_email_pattern 
CHECK (Email LIKE '%_@__%.__%');

🔍 How the Pattern '%_@__%.__%' Works:

  • %_ : At least one character before the @.
  • @__ : The @ symbol followed by at least two characters.
  • %.__% : A dot followed by at least two more characters (the domain extension).

⚠️ What happens if a constraint is violated?

If a user or a script tries to INSERT or UPDATE a row with an invalid email, SQL Server will immediately block the transaction and throw an error:

"The INSERT statement conflicted with the CHECK constraint 'chk_email'..."

Summary

Constraints are “set and forget” security for your data. Using CHARINDEX is lightweight, while LIKE patterns offer better structural enforcement. Choose the one that fits your business rules and keep your database clean!

Related posts:

SQL: Professional Soft Delete Strategy for Data Safety

How to check column data types of a table in SQL

What does COALESCE do in SQL?

Post Views: 578

Post navigation

Display HTPP Headers in C# & ASP.net
Get the First and Last Word from a String or Sentence in SQL

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

April 2026
M T W T F S S
 12345
6789101112
13141516171819
20212223242526
27282930  
« Mar    

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (950)
  • How to add default value for Entity Framework migrations for DateTime and Bool (859)
  • Get the First and Last Word from a String or Sentence in SQL (836)
  • How to select distinct rows in a datatable in C# (805)
  • How to make theater mode the default for Youtube (754)
  • Add Constraint to SQL Table to ensure email contains @ (578)
  • How to enable, disable and check if Service Broker is enabled on a database in SQL Server (564)
  • Average of all values in a column that are not zero in SQL (531)
  • How to use Map Mode for Vertical Scroll Mode in Visual Studio (489)
  • Find numbers with more than two decimal places in SQL (448)

Recent Posts

  • C#: Use Init-Only Setters for Immutable Objects After Construction
  • C#: Use Expression-Bodied Members for Concise Single-Line Methods
  • C#: Enable Nullable Reference Types to Eliminate Null Reference Exceptions
  • C#: Use Record Types for Immutable Data Objects
  • SQL: Use CTEs for Readable Complex Queries
  • SQL: Use Window Functions for Advanced Analytical Queries
  • .NET Core: Use Background Services for Long-Running Tasks
  • .NET Core: Use Minimal APIs for Lightweight HTTP Services
  • Git: Use Cherry-Pick to Apply Specific Commits Across Branches
  • Git: Use Interactive Rebase to Clean Up Commit History Before Merge

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (950)
  • How to add default value for Entity Framework migrations for DateTime and Bool (859)
  • Get the First and Last Word from a String or Sentence in SQL (836)
  • How to select distinct rows in a datatable in C# (805)
  • How to make theater mode the default for Youtube (754)

Recent Posts

  • C#: Use Init-Only Setters for Immutable Objects After Construction
  • C#: Use Expression-Bodied Members for Concise Single-Line Methods
  • C#: Enable Nullable Reference Types to Eliminate Null Reference Exceptions
  • C#: Use Record Types for Immutable Data Objects
  • SQL: Use CTEs for Readable Complex Queries

Social

  • ErcanOPAK.com
  • GoodReads
  • LetterBoxD
  • Linkedin
  • The Blog
  • Twitter
© 2026 Bits of .NET | Built with Xblog Plus free WordPress theme by wpthemespace.com