Skip to main content

SQL Server LIKE Operator

Like operator is used to search a specific pattern in a column value.

Syntax for like operator: match_expression [ NOT ] LIKE pattern [ ESCAPE escape_character ]

match_expression: is a character expression such as a column field

pattern: is a specific string of characters to search for match_expression
It can be maximum of 8000 bytes
Pattern can have these wild card
Wildcard character Description
% (percentage) 0 or more characters
_ (underscore) 1 character
[] (square bracket) any single character withing given range [defgh] or [d-h]
[^] (square bracket with negate) any single character not within the specific range [^d-h] or [^defgh]

escape_character: a character expression that has no default and must evaluate to only one character.
It's optional

LIKE return TRUE if the match_expression matches the specific pattern

POINT TO PONDER:
LIKE operator supports ASCII as well as Unicode pattern matching.

when all the arguments with LIKE operator (match_expression, pattern [escape_character if present]) are ASCII character data types, then ASCII pattern matching is performed.

If any of the arguments of LIKE operator is UNICODE data type, all arguments are converted to UNICODE, and the pattern matching is performed using UNICODE pattern matching.

nchar, nvarchar, ntext are UNICODE data types
Unicode pattern matching with LIKE operator, trailing spaces are significant. Unicode LIKE is compatible with the ISO standard.

ASCII pattern matching with LIKE operator, trailing space is not significant. ASCII LIKE is compatible with earlier versions of SQL Server.

Let's try to understand the UNICODE & ASCII pattern matching

------ ASCII pattern matching with char column (with 15 space)
CREATE TABLE ASCIIPatternTestTable (Name char(15));
INSERT INTO ASCIIPatternTestTable VALUES ('Ram Kumar');

-- data insert will be 'Ram Kumar      ' (means some blank space in right-hand-side)

SELECT * 
FROM ASCIIPatternTestTable 
WHERE Name LIKE '% Kumar';   -- returns 1 row

------ Unicode pattern matching with nchar column
CREATE TABLE UNICODEPatternTestTable (Name nchar(15));
INSERT INTO UNICODEPatternTestTable VALUES ('Ram Kumar');

-- data insert will be 'Ram Kumar      ' (means some blank space in right-hand-side)
SELECT * 
FROM UNICODEPatternTestTable
WHERE Name LIKE '% Kumar';   -- no rows returned

------ Unicode pattern matching with nchar column and RTRIM
CREATE TABLE t (col1 nchar (15));
INSERT INTO t VALUES ('Ram Kumar');

-- data insert will be 'Ram Kumar      ' (means some blank space in right-hand-side)
SELECT * 
FROM t 
WHERE RTRIM(col1) LIKE '% Kumar';   -- returns 1 row

Another point to keep in mind that like operator is also affected by collation.


Let's see some of the examples with the uses of different wildcard of LIKE operators

  1. using '%' (percentage) wildcard in like operator. % is used to find the 0 or more characters
       -- get all exmployees whose name start with "R"
       SELECT Id, Name 
       FROM Employees
       WHERE Name like 'R%';
       
       
       We can use % multiple times
       -- get all employees whose name is having "m" character in his name
       SELECT Id, Name
       FROM Employees
       WHERE Name like '%m%';
       
  2. using _ (underscore) wildcard in like operator. _ is used to find the 1 character
       -- get all employees where name field is having at least one character between 'R' & 'M'
       -- and which starts with R & ends with M
       SELECT Id, Name
       FROM Employees
       WHERE Name like 'R_M';
       
       we can use _ multiple times along with % wildcard as well
       -- get the result-set of all employees whose name field is having at least two charater between 'R' & 'M'
       SELECT Id, Name
       FROM Employees
       WHERE Name like '%R__M%';
       
  3. using [] (square bracket) wildcard. [] is used to find any single character within the given range
       -- get all employees whose name field is having one character eiher 'a' or 'i' in-between "R" & "MA"
       SELECT Id, Name
       FROM Employees
       WHERE Name like 'R[ai]MA';  -- RAMA or RIMA
       
  4. using [^] (square bracket with NOT) wildcard. [^] to negate the result-set from [] operator
        -- get all employees whose name field is not having one character eiher 'a' or 'i' in-between "R" & "MA"
       SELECT Id, Name
       FROM Employees
       WHERE Name like 'R[ai]MA';  -- except RAMA or RIMA
       
  5. using NOT operator with LIKE
       -- get all the employees whose name doesn't starts with "R"
       SELECT Id, Name
       FROM Employees
       WHERE Name NOT LIKE 'R%' ;
       
  6. using ESCAPE character Escape charater is being used to search for special character
       -- get all the employees where employee-code field is having [rm-%]
       
       SELECT Id, Name 
       FROM Employees
       WHERE EmployeeCode LIKE '\[rm-%\]' ;
       

Comments

Popular posts from this blog

EFCore - Collate function

Search in SQL server query is generally case insensitive (by default or based on database level collation). Suppose we have an employees table with a row having first-name column value as "My-First-Name", so if we want to do the case-sensitive search we have to explicitly use the related collate: In EF 5 (currently in Release Candidate version [RC.2.20475.6]) Collate function got introduced which helps us to use our specific collation based search.  C# with EF5 code sample: var employeeCaseSensitiveSearch = _dbContext.Employees .Where(x => EF.Functions.Collate(x.FirstName, "Latin1_General_CS_AS") == "my-first-name") .FirstOrDefault(); A related database query will be something like this: T-SQL: Case sensitive search (use specific collation e.g.: Latin1_General_CS_AS) SELECT * FROM dbo.Employees AS e WHERE e.FirstName Collate Latin1_General_CS_AS = 'my-first-name' Some of the useful CSharp function which g...

EFCore - Parallel db call on same dbContext

Practically there are multiple instances when we want to do parallel DB call which will save us some time. Like if we want to get a few employees details as well as users detail and if both entities are independent of each other better to go with a parallel call to fetch the details.  With the growing ORM usage and enhanced & optimized framework of like EFCore, in most of the application (related to C# development), we generally prefer to use EFCore. With EFCore if we try to use the same DB context to do parallel db call we are getting an error (... different thread using the same DbContext....). Because dbContext call is not thread-safe Parallel DB call on the same dbContext:  Code snipped: which will throw an error private void DbCallWithParallelCallOnSameDbContext() { try { var employeesTask = _dbContext.Employees.ToListAsync(); var usersTask = _dbContext.Users.ToListAsync(); ...

How to install Zen-coding plugin

As a web-developer, irrespective of the technologies (java, c-sharp, python, php e.t.c.…), we used to write CSS code to make our web-pages looks good if not at least we’re involved in write html codes. What if there is some tool to whom you give some instruction and that tool generates a good, well formatted html tags for you. These kind of coding is possible and known as “ Zen coding ” and there are lots of plug-in available from different vendors. We’re going to  discuss the steps to install this “zen-coding” plugin for “visual studio, eclipse, sublime-text & notepad++ in next few lines. Follow the below steps to install "zen-coding" plugin based on your editor.  Steps to install zen-coding plugin for (visual studio, eclipse, sublime-text,notepad++) -- -- For Visual Studio 1. Go to "Tools" -> "Extensions and Updates" 2. It'll open the "Extensions and Updates windows"    Select online form Left hand menu items ent...