Another quick post off the back of a SQL Lunch a did a while ago. Explore it via SQLFiddle: http://sqlfiddle.com/#!6/ad7f5/7/0
What is a CTE?
A Common Table Expression (CTE) is essentially a function defining a relation instead of a table.
This function outputs a table (like all queries) that is only present within the session, but data isn’t stored in tempdb like with a temporary table.
Why CTE’s?
CTEs are designed primarily to allow recursion within SQL – like a loop but ideal at working with hierarchies. This is excellent for tables that are self-referential … think employees!
Additionally, they’re great for generating sequences… think times, dates, etc
What’s the syntax?
WITH [Tbl Name] ([col],[names],..) AS ( SQL )
Produce multiple CTEs by comma separating them
WITH [Tbl Name] ([col],[names],..) AS ( SQL ), [Tbl Name 2] ([col],[names],..) AS ( SQL )
Then use a standard DML statement after it!
Where can I learn more?
https://www.simple-talk.com/sql/t-sql-programming/sql-server-cte-basics/
http://technet.microsoft.com/en-us/library/ms190766(v=sql.105).aspx
http://msdn.microsoft.com/en-gb/library/ms175972.aspx
http://blogs.msdn.com/b/sqlcat/archive/2011/04/28/optimize-recursive-cte-query.aspx