I am using sql2005 how to collect the first row values without using lead funtion
what is equal to lead funtion in sql server 2005
Mar 14, 2012 at 06:01 PM
Mr. Riley had an excellent answer to that in a similar question here.
Mar 14, 2012 at 08:15 PM
I think the OP's question was to find the previous rows values e.g. running total.
Ha! I think you're right. Obviously, I am not an Oracle developer.
BTW, Lead function is now available with SQL Server 2012 :)
There was a similar question in the past here. @WilliamDurkin answered using recursive CTE and I posted an answer using the quirky update which is a very fast method of calculating the running totals. Of course in SQL Server 2012 both LEAD and LAG are available as @Usman already mentioned, but in earlier versions the quirky update is a very good method to use. Here is the link:
Additionally, there is an excellent article by Jeff Moden titled Solving the Running Total and Ordinal Rank Problems (Rewritten). Please read it.
There is another very simple way, which consists of including the row_number() into select (partitioned on per account basis) and then it is possible to left join the result with itself on the "off-by-one" basis to have the values from the previous row available to the current row. This method is not as fast as quirky update but works well with record counts in 6 digits or less.
The same question I mentioned earlier also has a very good answer by @Pavel Pawlowski which uses the CLR function and it is also smoking fast.
Up to 2 attachments (including images) can be used with a maximum of 524.3 kB each and 1.0 MB total.
Once you sign in you will be able to subscribe for any updates here
Answers and Comments
Need long-form SQL discussion? SQLserverCentral.com is the place.
asked: Mar 14, 2012 at 06:01 PM
Seen: 2141 times
Last Updated: Mar 15, 2012 at 02:56 PM
Can't add SQL 2008 as a linked server in SQL 2005
reindex only non-clustered indexes
Find last occurrence of string in string sql 2005
SQL Server 2008 R2 installation
rebuild index maintainance plane?
DB mirroring - Manual failover with witness
Put SQLCMD output file on a share.
cpu usage high by Sqlserver? how to become normal??