Combine rows returned from within a Cursor loop into one Result

  • Is it possible to combine the Rows returned from a SQL running within a Cursor?

    DECLARE sla_cursor CURSOR FOR
    select Name from People
    OPEN sla_cursor

    FETCH NEXT FROM sla_cursor INTO @name

    WHILE @@FETCH_STATUS = 0
    BEGIN  
         select * from PeopleDetail where Name = @name
        
         FETCH NEXT FROM sla_cursor INTO @name
    END

    This would give one result set per Loop when I run the stored proc...

    Name Age Country
    Ana 21 US

    Name Age Country
    Mary 31 US

    Name Age Country
    John 21 US

    I would like to combine the result into one grid so that I can display it on a SSRS report

    Name Age Country
    Ana 21 US
    Mary 31 US
    John 21 US

    Any ideas?


  • SELECT *
    FROM PeopleDetail PD
    WHERE PD.Name IN (
        SELECT Name
        FROM People
    )

    SQL DBA,SQL Server MVP(07, 08, 09) "It's a dog-eat-dog world, and I'm wearing Milk-Bone underwear." "Norm", on "Cheers". Also from "Cheers", from "Carla": "You need to know 3 things about Tortelli men: Tortelli men draw women like flies; Tortelli men treat women like flies; Tortelli men's brains are in their flies".

  • ScottPletcher - Wednesday, April 25, 2018 11:11 AM


    SELECT *
    FROM PeopleDetail PD
    WHERE PD.Name IN (
        SELECT Name
        FROM People
    )

    Scott,

    Thanks for looking into this. What I have posted is a very simplistic example of the problem I am trying to solve. The cursor and the SQL running within is much more complex and would not fit into the solution above.

    I am just trying to see if there is a way to do what I require

    Thanks

  • QuietCoder - Wednesday, April 25, 2018 11:29 AM

    ScottPletcher - Wednesday, April 25, 2018 11:11 AM


    SELECT *
    FROM PeopleDetail PD
    WHERE PD.Name IN (
        SELECT Name
        FROM People
    )

    Scott,

    Thanks for looking into this. What I have posted is a very simplistic example of the problem I am trying to solve. The cursor and the SQL running within is much more complex and would not fit into the solution above.

    I am just trying to see if there is a way to do what I require

    Thanks

    Since you are the only one that can see the code, we have no idea if the cursor can be eliminated.  Just a guess, it probably can.  If you insist on keeping the cursor (or at least not seeing if it can be eliminated) just insert the results of each run of the code inside the cursor into a temporary table and then select the data from the table after you exit the cursor.

  • Is this what you mean:

    DECLARE @t table(name varchar(20), age tinyint, country varchar(20));
    SET NOCOUNT ON;
    INSERT @t ( name, age, country )
    VALUES ( 'Ana', 21, 'US' )
         , ( 'Mary', 31, 'US' ) 
         , ( 'John', 21, 'US' ) ;
    DECLARE @s-2 varchar(max) = '';
    SELECT @s-2 += name+' '+Cast(age AS varchar(3))+' '+country+Char(10)
    FROM @t t;
    PRINT @s-2;

    Ana 21 US
    Mary 31 US
    John 21 US

  • Lynn Pettis - Wednesday, April 25, 2018 11:56 AM

    QuietCoder - Wednesday, April 25, 2018 11:29 AM

    ScottPletcher - Wednesday, April 25, 2018 11:11 AM


    SELECT *
    FROM PeopleDetail PD
    WHERE PD.Name IN (
        SELECT Name
        FROM People
    )

    Scott,

    Thanks for looking into this. What I have posted is a very simplistic example of the problem I am trying to solve. The cursor and the SQL running within is much more complex and would not fit into the solution above.

    I am just trying to see if there is a way to do what I require

    Thanks

    Since you are the only one that can see the code, we have no idea if the cursor can be eliminated.  Just a guess, it probably can.  If you insist on keeping the cursor (or at least not seeing if it can be eliminated) just insert the results of each run of the code inside the cursor into a temporary table and then select the data from the table after you exit the cursor.

    Thanks Lynn! I think temp table is the way to go for me

  • QuietCoder - Wednesday, April 25, 2018 12:34 PM

    Lynn Pettis - Wednesday, April 25, 2018 11:56 AM

    QuietCoder - Wednesday, April 25, 2018 11:29 AM

    ScottPletcher - Wednesday, April 25, 2018 11:11 AM


    SELECT *
    FROM PeopleDetail PD
    WHERE PD.Name IN (
        SELECT Name
        FROM People
    )

    Scott,

    Thanks for looking into this. What I have posted is a very simplistic example of the problem I am trying to solve. The cursor and the SQL running within is much more complex and would not fit into the solution above.

    I am just trying to see if there is a way to do what I require

    Thanks

    Since you are the only one that can see the code, we have no idea if the cursor can be eliminated.  Just a guess, it probably can.  If you insist on keeping the cursor (or at least not seeing if it can be eliminated) just insert the results of each run of the code inside the cursor into a temporary table and then select the data from the table after you exit the cursor.

    Thanks Lynn! I think temp table is the way to go for me

    Actually, the way to go would be to try and eliminate the cursor if it can be eliminated.

  • QuietCoder - Wednesday, April 25, 2018 12:34 PM

    Lynn Pettis - Wednesday, April 25, 2018 11:56 AM

    QuietCoder - Wednesday, April 25, 2018 11:29 AM

    ScottPletcher - Wednesday, April 25, 2018 11:11 AM


    SELECT *
    FROM PeopleDetail PD
    WHERE PD.Name IN (
        SELECT Name
        FROM People
    )

    Scott,

    Thanks for looking into this. What I have posted is a very simplistic example of the problem I am trying to solve. The cursor and the SQL running within is much more complex and would not fit into the solution above.

    I am just trying to see if there is a way to do what I require

    Thanks

    Since you are the only one that can see the code, we have no idea if the cursor can be eliminated.  Just a guess, it probably can.  If you insist on keeping the cursor (or at least not seeing if it can be eliminated) just insert the results of each run of the code inside the cursor into a temporary table and then select the data from the table after you exit the cursor.

    Thanks Lynn! I think temp table is the way to go for me

    I am working on a presentation to eliminate cursors.  If you would like, PM me the code and we will see what happens.

  • Lynn Pettis - Wednesday, April 25, 2018 12:55 PM

    QuietCoder - Wednesday, April 25, 2018 12:34 PM

    Lynn Pettis - Wednesday, April 25, 2018 11:56 AM

    QuietCoder - Wednesday, April 25, 2018 11:29 AM

    ScottPletcher - Wednesday, April 25, 2018 11:11 AM


    SELECT *
    FROM PeopleDetail PD
    WHERE PD.Name IN (
        SELECT Name
        FROM People
    )

    Scott,

    Thanks for looking into this. What I have posted is a very simplistic example of the problem I am trying to solve. The cursor and the SQL running within is much more complex and would not fit into the solution above.

    I am just trying to see if there is a way to do what I require

    Thanks

    Since you are the only one that can see the code, we have no idea if the cursor can be eliminated.  Just a guess, it probably can.  If you insist on keeping the cursor (or at least not seeing if it can be eliminated) just insert the results of each run of the code inside the cursor into a temporary table and then select the data from the table after you exit the cursor.

    Thanks Lynn! I think temp table is the way to go for me

    I am working on a presentation to eliminate cursors.  If you would like, PM me the code and we will see what happens.

    Lynn,

    Thank you for pushing me to eliminate the cursor. It did not seem possible when I wrote this post but your sheer confidence in the probability pushed me to look at the problem differently and I was able to do it!

    Thank you!

  • QuietCoder - Monday, April 30, 2018 2:37 PM

    Lynn Pettis - Wednesday, April 25, 2018 12:55 PM

    QuietCoder - Wednesday, April 25, 2018 12:34 PM

    Lynn Pettis - Wednesday, April 25, 2018 11:56 AM

    QuietCoder - Wednesday, April 25, 2018 11:29 AM

    ScottPletcher - Wednesday, April 25, 2018 11:11 AM


    SELECT *
    FROM PeopleDetail PD
    WHERE PD.Name IN (
        SELECT Name
        FROM People
    )

    Scott,

    Thanks for looking into this. What I have posted is a very simplistic example of the problem I am trying to solve. The cursor and the SQL running within is much more complex and would not fit into the solution above.

    I am just trying to see if there is a way to do what I require

    Thanks

    Since you are the only one that can see the code, we have no idea if the cursor can be eliminated.  Just a guess, it probably can.  If you insist on keeping the cursor (or at least not seeing if it can be eliminated) just insert the results of each run of the code inside the cursor into a temporary table and then select the data from the table after you exit the cursor.

    Thanks Lynn! I think temp table is the way to go for me

    I am working on a presentation to eliminate cursors.  If you would like, PM me the code and we will see what happens.

    Lynn,

    Thank you for pushing me to eliminate the cursor. It did not seem possible when I wrote this post but your sheer confidence in the probability pushed me to look at the problem differently and I was able to do it!

    Thank you!

    Glad you took the time.  Feels good, doesn't it.

  • QuietCoder - Wednesday, April 25, 2018 11:29 AM

    ScottPletcher - Wednesday, April 25, 2018 11:11 AM


    SELECT *
    FROM PeopleDetail PD
    WHERE PD.Name IN (
        SELECT Name
        FROM People
    )

    Scott,

    Thanks for looking into this. What I have posted is a very simplistic example of the problem I am trying to solve. The cursor and the SQL running within is much more complex and would not fit into the solution above.

    I am just trying to see if there is a way to do what I require

    Thanks

    Can you post the actual query instead of the simplified example please?
    😎

    I am yet to see a cursor query that is too complex to combine into a set based approach.

  • Eirikur Eiriksson - Tuesday, May 1, 2018 3:00 AM

    QuietCoder - Wednesday, April 25, 2018 11:29 AM

    ScottPletcher - Wednesday, April 25, 2018 11:11 AM


    SELECT *
    FROM PeopleDetail PD
    WHERE PD.Name IN (
        SELECT Name
        FROM People
    )

    Scott,

    Thanks for looking into this. What I have posted is a very simplistic example of the problem I am trying to solve. The cursor and the SQL running within is much more complex and would not fit into the solution above.

    I am just trying to see if there is a way to do what I require

    Thanks

    Can you post the actual query instead of the simplified example please?
    😎

    I am yet to see a cursor query that is too complex to combine into a set based approach.

    Eirikur, look up a couple of posts.

Viewing 12 posts - 1 through 11 (of 11 total)

You must be logged in to reply to this topic. Login to reply