<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Diário de um DBA &#187; Numerar linhas</title>
	<atom:link href="http://silasmendes.com/dba/tag/numerar-linhas/feed" rel="self" type="application/rss+xml" />
	<link>http://silasmendes.com/dba</link>
	<description>Tecnologia &#38; Banco de Dados</description>
	<lastBuildDate>Sun, 15 Apr 2012 12:20:16 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<item>
		<title>Ranking usando ROW_NUMBER()</title>
		<link>http://silasmendes.com/dba/sql-2005-row_number</link>
		<comments>http://silasmendes.com/dba/sql-2005-row_number#comments</comments>
		<pubDate>Tue, 22 Jul 2008 23:40:22 +0000</pubDate>
		<dc:creator>Silas Mendes</dc:creator>
				<category><![CDATA[Dica rápida]]></category>
		<category><![CDATA[Programação]]></category>
		<category><![CDATA[SQL SERVER 2000]]></category>
		<category><![CDATA[SQL SERVER 2005]]></category>
		<category><![CDATA[SQL SERVER 2008]]></category>
		<category><![CDATA[SQL SERVER 2008 R2]]></category>
		<category><![CDATA[SQL SERVER 7]]></category>
		<category><![CDATA[Numerar linhas]]></category>
		<category><![CDATA[ranking]]></category>
		<category><![CDATA[ROW_NUMBER()]]></category>
		<category><![CDATA[Sequencial]]></category>

		<guid isPermaLink="false">http://diariodba.wordpress.com/?p=29</guid>
		<description><![CDATA[Existem algumas coisas que não sabemos da existência, outras até conhecemos mas não temos idéia do dia que precisaremos delas.  Há uns quatro anos eu precisava realizar uma consulta e retornar uma coluna com um seqüencial, numerando as linhas, algo &#8230; <a href="http://silasmendes.com/dba/sql-2005-row_number">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p style="margin:0;">Existem algumas coisas que não sabemos da existência, outras até conhecemos mas não temos idéia do dia que precisaremos delas. </p>
<p style="margin:0;">Há uns quatro anos eu precisava realizar uma consulta e retornar uma coluna com um seqüencial, numerando as linhas, algo bem simples assim:</p>
<p style="margin:0;"> </p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:8pt;font-family:&quot;">cod_produto <span>   </span>des_produto<span>                    </span>sequencial</span></p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:8pt;font-family:&quot;">&#8212;&#8212;&#8212;&#8212;&#8211; &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212; &#8212;&#8212;&#8212;&#8212;-</span></p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:8pt;font-family:&quot;">516E<span>           </span>Arroz<span>                            </span><span>    </span>1</span></p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:8pt;font-family:&quot;">03G<span>           </span><span> </span>Azeitona<span>                      </span><span>     </span>2</span></p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:8pt;font-family:&quot;">98K<span>           </span><span> </span>Salame<span>                            </span><span>  </span>3</span></p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:8pt;font-family:&quot;">514A<span>           </span>Tomate <span>                           </span>4</span></p>
<p class="MsoNormal" style="margin:0;"> </p>
<p style="margin:0;">Como retornar um sequencial num comando Select simples? Eu não queria usar cursor, nem uma tabela auxiliar, nada disso, queria apenas um seqüencial, simples e objetivo. Enfim, procurei diversos meios e até hoje não soube uma forma <span style="text-decoration: underline;">simples</span> de fazer isso no SQL Server 2000.</p>
<p style="margin:0;"> </p>
<p class="MsoNormal" style="margin:0;">Com o SQL Server 2005 aquele bordão “Seus problemas acabaram” cabe perfeitamente nesse cenário. Existe uma função <strong>Row_Number()</strong> que  faz exatamente isso. Veja um exemplo:</p>
<p class="MsoNormal" style="margin:0;"> </p>
<blockquote>
<p style="margin:0;"><span style="font-size:10pt;color:#0000ff;font-family:&quot;">SELECT</span><span style="font-size:10pt;font-family:&quot;"> </span></p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:10pt;font-family:&quot;"><span>      </span>cod_produto<span style="color:#808080;">,</span> </span></p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:10pt;font-family:&quot;"><span>      </span>des_produto<span style="color:#808080;">,</span> </span></p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:10pt;font-family:&quot;"><span>      </span></span><span style="font-size:10pt;color:#ff00ff;font-family:&quot;">ROW_NUMBER</span><span style="font-size:10pt;color:#808080;font-family:&quot;">()</span><span style="font-size:10pt;font-family:&quot;"> <span style="color:#0000ff;">over</span> <span style="color:#808080;">(</span><span style="color:#0000ff;">order</span> <span style="color:#0000ff;">by</span> des_produto<span style="color:#808080;">)</span> sequencial</span></p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:10pt;color:#0000ff;font-family:&quot;">FROM</span></p>
<p class="MsoNormal" style="margin:0;"><span style="font-size:10pt;font-family:&quot;"><span>      </span>tb_teste_produto</span></p>
</blockquote>
<p class="MsoNormal" style="margin:0;">Como fica subtendido a consulta SQL irá retornar os campos da tabela mais um campo  seqüencial baseado na ordenação do nome do produto. </p>
<p style="margin:0;">Simples não é? </p>
<p style="margin:0;">Trabalhando com subconsultas é possível por exemplo atualizar todos os registros entre as linhas 60 e 80 de uma consulta&#8230; é o T-SQL dando suporte às nossas necessidades!</p>
<p style="margin:0;">Se você tem outra solução para este cenário contribua deixando seu comentário :)</p>
<p style="margin:0;"> </p>
]]></content:encoded>
			<wfw:commentRss>http://silasmendes.com/dba/sql-2005-row_number/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
	</channel>
</rss>

