Dear readers of our blog, we'd like to recommend you to visit the main page of our website, where you can learn about our product SQLS*Plus and its advantages.
 
SQLS*Plus - best SQL Server command line reporting and automation tool! SQLS*Plus is several orders of magnitude better than SQL Server sqlcmd and osql command line tools.
 

REQUEST COMPLIMENTARY SQLS*PLUS LICENCE

Enteros UpBeat offers a patented database performance management SaaS platform. It proactively identifies root causes of complex revenue-impacting database performance issues across a growing number of RDBMS, NoSQL, and deep/machine learning database platforms. We support Oracle, SQL Server, IBM DB2, MongoDB, Casandra, MySQL, Amazon Aurora, and other database systems.

CHARINDEX SQL Server function

20 June 2020

CHARINDEX SQL Server function

In SQL Server (Transact-SQL), the CHARINDEX function returns the substring location in a string. The search is case insensitive.

Syntax of the CHARINDEX function in SQL Server (Transact-SQL):

CHARINDEX( substring, string, [start_position] )

CHARINDEX function parameters or arguments in SQL Server (Transact-SQL)

  • It’s a substring you want to find.
  • string – the string in which the search is performed.
  • start_position – optional. The position in the string, from which the search will start.

Note:

  1. The first position in the line is 1.
  2. If the substring is not found in the string, the CHARINDEX function will return 0.

Application:
The CHARINDEX function can be used in the following versions of SQL Server (Transact-SQL):
SQL Server vNext, SQL Server 2016, SQL Server 2015, SQL Server 2014, SQL Server 2012, SQL Server 2008 R2, SQL Server 2008, SQL Server 2005

Example:
Consider some examples of the CHARINDEX SQL Server function to understand how to use the CHARINDEX function in SQL Server (Transact-SQL). For example:

SELECT CHARINDEX('s', 'SQL Server');
--Result: 1 (the search is case insensitive, so it will match 'S')

SELECT CHARINDEX('s', 'SQL Server', 2);
--Result: 5

SELECT CHARINDEX('ER', 'SQL Server');
--Result: 6 (the search is case insensitive, so it will match 'er').

SELECT CHARINDEX('x', 'SQL Server');
--Result: 0

The CHARINDEX function has syntax:

CHARINDEX( search_expression, string_expression [, start_position ])

Here the optional integer parameter start_position defines the position in the string expression, starting from which the search is performed. If this parameter is omitted, the search is performed from the beginning of the string_expression.

For example, the query:

SELECT name
FROM Ships
WHERE CHARINDEX('sh', name) > 0;

will output those ships that have a combination of “sh” characters. It uses the fact that if the sought string is not found, the CHARINDEX function returns 0. The result of the query will contain the following ships:

name
Kirishima
Musashi
Washington

It should be noted that if the sought substring or string expression is NULL, the result of the function will also be NULL.

The following example defines the position of the first and second occurrence of the symbol a in the ship name California:

SELECT CHARINDEX('a',name) first_a,
CHARINDEX('a', name, CHARINDEX('a', name)+1) second_a
FROM Ships
WHERE name='California';

Note that when defining the second character, the CHARINDEX function uses the starting position, which is the position following the first letter of a character – CHARINDEX(‘a’, name)+1. The correctness of the result – 2 and 10 – is easy to check.

 
Tags: , , , ,

MORE NEWS

 

Preamble​​NoSql is not a replacement for SQL databases but is a valid alternative for many situations where standard SQL is not the best approach for...

Preamble​​MongoDB Conditional operators specify a condition to which the value of the document field shall correspond.Comparison Query Operators $eq...

5 Database management trends impacting database administrationIn the realm of database management systems, moreover half (52%) of your competitors feel...

The data type is defined as the type of data that any column or variable can store in MS SQL Server. What is the data type? When you create any table or...

Preamble​​MS SQL Server is a client-server architecture. MS SQL Server process starts with the client application sending a query.SQL Server accepts,...

First the basics: what is the master/slave?One database server (“master”) responds and can do anything. A lot of other database servers store copies of all...

Preamble​​Atom Hopper (based on Apache Abdera) for those who may not know is an open-source project sponsored by Rackspace. Today we will figure out how to...

Preamble​​MongoDB recently introduced its new aggregation structure. This structure provides a simpler solution for calculating aggregated values rather...

FlexibilityOne of the most advertised features of MongoDB is its flexibility.  Flexibility, however, is a double-edged sword. More flexibility means more...

Preamble​​SQLShell is a cross-platform command-line tool for SQL, similar to psql for PostgreSQL or MySQL command-line tool for MySQL.Why use it?If you...

Preamble​​Writing an application on top of the framework on top of the driver on top of the database is a bit like a game on the phone: you say “insert...

Preamble​​Oracle Coherence is a distributed cache that is functionally comparable with Memcached. In addition to the basic function of the API cache, it...

Preamble​​IBM pureXML, a proprietary XML database built on a relational mechanism (designed for puns) that offers both relational ( SQL / XML ) and...

  What is PostgreSQL array? In PostgreSQL we can define a column as an array of valid data types. The data type can be built-in, custom or enumerated....

Preamble​​If you are a Linux sysadmin or developer, there comes a time when you need to manage an Oracle database that can work in your environment.In this...

Preamble​​Starting with Microsoft SQL Server 2008, by default, the group of local administrators is no longer added to SQL Server administrators during the...