November 6, 2008 at 11:50 am
1. Why does the pivot table need the aggregate function MIN in order to work?
2. Why did you need the column Row_number?
1. PIVOT needs an aggregate function you could have use MAX() or even AVG() too because it will really be applied to only one row.
2. We need to identify 4 columns values that will be repeated "exactly" row-by-row with 4 possible values which in the source table you don't have. To see it in a clearer manner just run the Src query by it self and inspect the results.
HTH
* Noel
November 6, 2008 at 1:07 pm
noeld (11/6/2008)
1. Why does the pivot table need the aggregate function MIN in order to work?
2. Why did you need the column Row_number?
1. PIVOT needs an aggregate function you could have use MAX() or even AVG() too because it will really be applied to only one row.
2. We need to identify 4 columns values that will be repeated "exactly" row-by-row with 4 possible values which in the source table you don't have. To see it in a clearer manner just run the Src query by it self and inspect the results.
HTH
I want to thank you and everyone else who pitched in to help me out.
Thanks again
November 6, 2008 at 1:12 pm
Happy to help
* Noel
May 24, 2011 at 2:17 am
DECLARE @table TABLE (Name VARCHAR(10), Mark1 INT, Mark2 INT,Mark3 INT,Mark4 INT)
INSERT INTO @table (Name, mark1, mark2, Mark3, Mark4) SELECT 'Liju',1,2,3,4
INSERT INTO @table (Name, mark1, mark2, Mark3, Mark4) SELECT 'Siju',10,20,30,40
INSERT INTO @table (Name, mark1, mark2, Mark3, Mark4) SELECT 'Biju',11,12,13,14
INSERT INTO @table (Name, mark1, mark2, Mark3, Mark4) SELECT 'Viju',11,21,31,41
SELECT * FROM @table
DECLARE @Result AS NVARCHAR(1000)
SET @Result =''
SELECT @Result = @Result + Name +','+ CAST(mark1 AS NVARCHAR(10)) + ',' + CAST(mark2 AS NVARCHAR(10)) + ','
FROM @table
WHERE Name = 'Liju'
SELECT @Result
May 24, 2011 at 8:26 am
First, this thread is almost three years old.
Second, the OP has a table that is normalized and asks how to denormalize it. Your sample data starts out denormalized. If you're going to resurrect old threads, make absolutely sure that you understand the question that was being asked.
lijusankar (5/24/2011)
DECLARE @table TABLE (Name VARCHAR(10), Mark1 INT, Mark2 INT,Mark3 INT,Mark4 INT)
Drew
J. Drew Allen
Business Intelligence Analyst
Philadelphia, PA
March 20, 2012 at 9:14 am
I'm new to SQL so this is more a question than a statement, but couldn't you select the data into a temp table, then count the records to set a variable for a while loop?
DECLARE @i int
DECLARE @OrderNo varchar(100)
DECLARE @qty1 varchar(100)
DECLARE @qty2 varchar(100)
DECLARE @qty3 varchar(100)
DECLARE @qty4 varchar(100)
--obviously change the vars to whatever type you like
SELECT INTO ##tempTable1
OrderNo, Qty
FROM whateverTable
Where OrderNo = '00001'
--returns 3 records
while @i < (Select Count(*) from ##tempTable1)
begin
--build a cursor - for each row in tempTable1
SET @OrderNo = (SELECT OrderNo From ##tempTable1)
SET (@qty + @i) = (Select Qty From ##tempTable1)
insert into ##tempTable2
@OrderNo,@qty1,@qty2,@qty3
--destory the cursor
Am I way off base on this? How whould this effect performance
March 20, 2012 at 9:23 am
We don't like cursors much here 🙂 Can you tell us what you are trying to achieve & we'll almost certainly find a faster way to do it.
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
March 20, 2012 at 9:48 am
Sorry, I was posting a response to another person, but I posted to the wrong location.
March 20, 2012 at 3:09 pm
Like other people suggest i would approach this using a pivot table, why does you boss object to a using pivot?
***The first step is always the hardest *******
March 21, 2012 at 6:40 am
SGT_squeequal (3/20/2012)
Like other people suggest i would approach this using a pivot table, why does you boss object to a using pivot?
You do realize that that comment was made THREE YEARS AGO? I suspect that the situation has changed in the intervening three years.
Drew
J. Drew Allen
Business Intelligence Analyst
Philadelphia, PA
March 22, 2012 at 11:46 am
no need to shout, no i do not look at the dates in the post, it appeard as a topic entered in the last 24 hours therefore are current posts
***The first step is always the hardest *******
March 27, 2012 at 7:03 am
@ SGT_squeequal - Thank you for responding to my post in a helpful and informative manner.
@ Drew Allen - Normally, I don't respond to people that are being rude, but I've recently decided to change my stance on this policy.
Honestly, who cares if the post is THREE YEARS OLD? If someone has an answer, it would be nice to see it posted, and there is the possibility that someone else is having, or will have the same or an similar issue in the future. Some of us new guys like to search the posts for an answer before we ask a question, and read these posts for general knowledge. CHILL OUT!!!
Viewing 12 posts - 16 through 26 (of 26 total)
You must be logged in to reply to this topic. Login to reply