RU EN
Jan 2, 2023

Common Table Expression (CTE) in SQL Server

Автор:
Rajesh Gami
Источник:
Просмотров:
4313
Common Table Expression (CTE) in SQL Server favorites 0

Simplify complex joins and subqueries using SQL Server Common Table Expressions or CTEs. It also provides a way to query hierarchical data. This article provides a complete overview of CTEs, types of CTEs, benefits, drawbacks, and how to use them with SQL Server.

A Common Table Expression or CTE is a short-lived named result set created from an easy SELECT statement employed in a subsequent SELECT statement. Every SQL CTE is sort of a named query, the result of which is kept in a very virtual table (a CTE) which is referenced later within the main query.

Syntax

WITH cte_expression_name[ ( column_name [,...n] ) ] AS ( CTE_query_definition )

To view the CTE results, use a select query with the name of the CTE expression.

Select [Column1,Column2,Column3,Column4...] from cte_expression_name OR SELECT * FROM cte_expression_name

Types of CTE (Common Table Expression)

There are 2 types of CTEs,

  1. Recursive CTE. 
  2. Non-Recursive CTE.

Recursive CTE

A Recursive common table expression (CTE) could be a CTE that references itself. By doing so, the CTE repeatedly executes, and returns subsets of information, till it returns the whole result set.

A recursive CTE is beneficial in querying ranked data adore organization charts wherever one worker reports to a manager or multi-level bill of materials once a product consists of many components, and every component itself additionally consists of many different components.

We'll see how to use a CTE to create a simple recursive query that displays row numbers from 1 to 10.

First, he declared an integer variable as 'RowNo', set the default value to 1, and created our first CTE query as the expression name 'ROW_CTE'. This CTE first displays the default row number, then uses union ALL to increment the row number by 1 until the row number reaches the incremented value of 10. To view the results, use the query of your choice to view the CTE results.

Declare @RowNo int =1; ;with ROW_CTE as    (       SELECT @RowNo as ROWNO         UNION ALL       SELECT  ROWNO+1   FROM  ROW_CTE   WHERE RowNo < 10     ) SELECT * FROM ROW_CTE

Output

ROWNO  1  2  3  4  5  6  7  8  9  10

Non-Recursive CTE

Non-Recursive CTEs are easy in which the CTE doesn’t use any recursion, or repeated processing in of a sub-routine. We will create an easy Non-Recursive CTE to show the row variety from 1 to 10.

As in keeping with the CTE Syntax, every CTE question will begin with a "With" observed with the aid of using the CTE Expression call with a column list.

Here we had been the usage of only one column as ROWNO. Next is the Query part, right here we write our pick-out question to be executed for our CTE. After developing our CTE question to run the CTE uses the pick out an announcement with the CTE Expression call.

;with ROW_CTE(ROWNO) as    (      SELECT   ROW_NUMBER() OVER(ORDER BY name ASC) AS ROWNO FROM table_name WHERE id <= 10     ) SELECT * FROM ROW_CTE Output: ROWNO  1  2  3  4  5  6  7  8  9  10

Nested CTE (Common Table Expression)

WITH First_CTE    AS (SELECT 1 EmpId, 'Rajesh Gami' Name)   ,Second_CTE    AS (SELECT EmpID, Name, 'Gujarat' State FROM First_CTE) SELECT *   FROM Second_CTE

Похожее
Jun 13, 2023
One of the things that we may struggle with as developers when working on a green field project is our stack. Choosing the right tech to solve a problem can be a harrowing experience. Databases, in particular, can be a...
Dec 27, 2024
If you work with a PostgreSQL database and if you’re looking for some awesome GUI tools to execute your SQL scripts, you’ve come to the right place. In this article, we will introduce you to the top 5 GUI tools...
Apr 3, 2013
Introduction This is just a simple article visually explaining SQL JOINs. Background I'm a pretty visual person. Things seem to make more sense as a picture. I looked all over the Internet for a good graphical representation of SQL JOINs,...
6 июля 2015 г.
Чаще всего deadlock описывают примерно следующим образом: • Процесс 1 блокирует ресурс А. • Процесс 2 блокирует ресурс Б. • Процесс 1 пытается получить доступ к ресурсу Б. • Процесс 2 пытается получить доступ к ресурсу А. В итоге один...
Написать сообщение
Тип
Почта
Имя
*Сообщение
RSS
Если вам понравился этот сайт и вы хотите меня поддержать, вы можете
Using a сustom PagedList class for Generic Pagination in .NET Core
Soft skills: 18 самых важных навыков, которыми должен владеть каждый работник
GraphQL решает кучу проблем — рассказываем, за что мы его любим
5 ошибок при разработке высоконагруженных сервисов
Стили именования переменных и функций. Используйте их все
Выйди и зайди правильно
«Спасите C++»: отец легендарного языка просит разработчиков о помощи
Функции и хранимые процедуры в PostgreSQL: зачем нужны и как применять в реальных примерах
Несколько вещей, о которых стоит помнить программисту в возрасте
Из интровертов в менторы: как мидлы становятся сеньорами
Boosty
Donate to support the project
GitHub account
GitHub profile
Complete your gift to make an impact