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: 2137 times
Last Updated: Mar 15, 2012 at 02:56 PM
INSTALLED SQL SERVER ON SERVER 2003: Cannot find installed Services.
how Automatically update the database using jobs daily ?
SQL pulling data
What all connections does MS SQL server support ?
Merge Replication Error
using a particuler format for variable in ssis
Pick 1st occurrence of +1... phone number
Visibly empty packagedata field in the msdb.dbo.sysdtspackages90 table
replicating user and group permissions