INSERT to a table from a database to other (same SQL Server) using Dynamic SQL The Next CEO of Stack OverflowHow to Dynamically change the database using TSQLHow the indexes are managed?Script to query multiple instancesHow to avoid using variables in WHERE clauseOracle GoldenGate add trandata errorsCreate A View Using Dynamic SqlDynamic Pivot SQL tableSyntax Error HelpInvestigating errors from strange queryDynamic SQL isn't updating tableHow to copy all Database from Source to Destination server along with login credentials?

Should I tutor a student who I know has cheated on their homework?

Reference request: Grassmannian and Plucker coordinates in type B, C, D

What was the first Unix version to run on a microcomputer?

INSERT to a table from a database to other (same SQL Server) using Dynamic SQL

The exact meaning of 'Mom made me a sandwich'

Make solar eclipses exceedingly rare, but still have new moons

What happened in Rome, when the western empire "fell"?

Running a General Election and the European Elections together

How a 64-bit process virtual address space is divided in Linux?

How to install OpenCV on Raspbian Stretch?

Newlines in BSD sed vs gsed

Is micro rebar a better way to reinforce concrete than rebar?

Which one is the true statement?

Unreliable Magic - Is it worth it?

Why isn't the Mueller report being released completely and unredacted?

Is there a difference between "Fahrstuhl" and "Aufzug"

Is it ever safe to open a suspicious HTML file (e.g. email attachment)?

Why is my new battery behaving weirdly?

Is it okay to majorly distort historical facts while writing a fiction story?

Does increasing your ability score affect your main stat?

RigExpert AA-35 - Interpreting The Information

Is it professional to write unrelated content in an almost-empty email?

What did we know about the Kessel run before the prequels?

Why is the US ranked as #45 in Press Freedom ratings, despite its extremely permissive free speech laws?



INSERT to a table from a database to other (same SQL Server) using Dynamic SQL



The Next CEO of Stack OverflowHow to Dynamically change the database using TSQLHow the indexes are managed?Script to query multiple instancesHow to avoid using variables in WHERE clauseOracle GoldenGate add trandata errorsCreate A View Using Dynamic SqlDynamic Pivot SQL tableSyntax Error HelpInvestigating errors from strange queryDynamic SQL isn't updating tableHow to copy all Database from Source to Destination server along with login credentials?










3















I need to copy a record from a Database DBa, Table Tbl1 to Database DBx, Table Tbl1 and get the Scope Identity inside the same SQL Server 2005 server



I have already checked this:
How to Dynamically change the database using TSQL



but my issue is more complicated.



I do want just to execute something in the DBx being inside DBa.
I want to copy a record from one database to one of the other (same) databases in the same server and get the scope_identity back.



The Dynamic SQL is a string. What do we do when we want to copy variables of other datatypes as well?



Example code:



CREATE PROCEDURE dbo.pr_consolidation_copy_group @group_id numeric(10,0),@database_to varchar(100)
AS

DECLARE @group_name char(100),@arrival datetime,@departure datetime,@contact_id char(82)

SELECT @group_name = group_name ,
@arrival = arrival,
@departure = departure,
@contact_id = contact_id
FROM grp
WHERE group_id = @group_id


DECLARE @exec nvarchar(max) = QUOTENAME(@database_to) + N'.sys.sp_executesql',
@sql nvarchar(max) = N'INSERT grp(group_name, arrival, departure, contact_id)
SELECT @group_name, @arrival, @departure, @contact_id;SELECT SCOPE_IDENTITY()'; //How do we handle the variables?

EXEC @exec @sql;
go


Get all variables to string and put CONVERT inside the Dynamic SQL?
I hope I can find another solution because my table is around 300 columns :(










share|improve this question




























    3















    I need to copy a record from a Database DBa, Table Tbl1 to Database DBx, Table Tbl1 and get the Scope Identity inside the same SQL Server 2005 server



    I have already checked this:
    How to Dynamically change the database using TSQL



    but my issue is more complicated.



    I do want just to execute something in the DBx being inside DBa.
    I want to copy a record from one database to one of the other (same) databases in the same server and get the scope_identity back.



    The Dynamic SQL is a string. What do we do when we want to copy variables of other datatypes as well?



    Example code:



    CREATE PROCEDURE dbo.pr_consolidation_copy_group @group_id numeric(10,0),@database_to varchar(100)
    AS

    DECLARE @group_name char(100),@arrival datetime,@departure datetime,@contact_id char(82)

    SELECT @group_name = group_name ,
    @arrival = arrival,
    @departure = departure,
    @contact_id = contact_id
    FROM grp
    WHERE group_id = @group_id


    DECLARE @exec nvarchar(max) = QUOTENAME(@database_to) + N'.sys.sp_executesql',
    @sql nvarchar(max) = N'INSERT grp(group_name, arrival, departure, contact_id)
    SELECT @group_name, @arrival, @departure, @contact_id;SELECT SCOPE_IDENTITY()'; //How do we handle the variables?

    EXEC @exec @sql;
    go


    Get all variables to string and put CONVERT inside the Dynamic SQL?
    I hope I can find another solution because my table is around 300 columns :(










    share|improve this question


























      3












      3








      3








      I need to copy a record from a Database DBa, Table Tbl1 to Database DBx, Table Tbl1 and get the Scope Identity inside the same SQL Server 2005 server



      I have already checked this:
      How to Dynamically change the database using TSQL



      but my issue is more complicated.



      I do want just to execute something in the DBx being inside DBa.
      I want to copy a record from one database to one of the other (same) databases in the same server and get the scope_identity back.



      The Dynamic SQL is a string. What do we do when we want to copy variables of other datatypes as well?



      Example code:



      CREATE PROCEDURE dbo.pr_consolidation_copy_group @group_id numeric(10,0),@database_to varchar(100)
      AS

      DECLARE @group_name char(100),@arrival datetime,@departure datetime,@contact_id char(82)

      SELECT @group_name = group_name ,
      @arrival = arrival,
      @departure = departure,
      @contact_id = contact_id
      FROM grp
      WHERE group_id = @group_id


      DECLARE @exec nvarchar(max) = QUOTENAME(@database_to) + N'.sys.sp_executesql',
      @sql nvarchar(max) = N'INSERT grp(group_name, arrival, departure, contact_id)
      SELECT @group_name, @arrival, @departure, @contact_id;SELECT SCOPE_IDENTITY()'; //How do we handle the variables?

      EXEC @exec @sql;
      go


      Get all variables to string and put CONVERT inside the Dynamic SQL?
      I hope I can find another solution because my table is around 300 columns :(










      share|improve this question
















      I need to copy a record from a Database DBa, Table Tbl1 to Database DBx, Table Tbl1 and get the Scope Identity inside the same SQL Server 2005 server



      I have already checked this:
      How to Dynamically change the database using TSQL



      but my issue is more complicated.



      I do want just to execute something in the DBx being inside DBa.
      I want to copy a record from one database to one of the other (same) databases in the same server and get the scope_identity back.



      The Dynamic SQL is a string. What do we do when we want to copy variables of other datatypes as well?



      Example code:



      CREATE PROCEDURE dbo.pr_consolidation_copy_group @group_id numeric(10,0),@database_to varchar(100)
      AS

      DECLARE @group_name char(100),@arrival datetime,@departure datetime,@contact_id char(82)

      SELECT @group_name = group_name ,
      @arrival = arrival,
      @departure = departure,
      @contact_id = contact_id
      FROM grp
      WHERE group_id = @group_id


      DECLARE @exec nvarchar(max) = QUOTENAME(@database_to) + N'.sys.sp_executesql',
      @sql nvarchar(max) = N'INSERT grp(group_name, arrival, departure, contact_id)
      SELECT @group_name, @arrival, @departure, @contact_id;SELECT SCOPE_IDENTITY()'; //How do we handle the variables?

      EXEC @exec @sql;
      go


      Get all variables to string and put CONVERT inside the Dynamic SQL?
      I hope I can find another solution because my table is around 300 columns :(







      sql-server dynamic-sql






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited 3 hours ago







      PanosPlat

















      asked 3 hours ago









      PanosPlatPanosPlat

      2571410




      2571410




















          1 Answer
          1






          active

          oldest

          votes


















          3














          Unless I am mistaken, your problem is not as complicated as you think. From what I understand, you want to take some data from your current database, store it in variables and then insert that into another database, returning the id that was inserted. If so, this will do what you need:



          CREATE PROCEDURE dbo.pr_consolidation_copy_group (
          @group_id numeric(10,0),
          @database_to varchar(100)
          )
          AS
          SET NOCOUNT ON;

          DECLARE @group_name char(100)
          ,@arrival datetime
          ,@departure datetime
          ,@contact_id char(82);

          SELECT @group_name = group_name ,
          @arrival = arrival,
          @departure = departure,
          @contact_id = contact_id
          FROM grp
          WHERE group_id = @group_id;

          DECLARE @sql_cmd NVARCHAR(MAX);
          SET @sql_cmd = 'USE ' + QUOTENAME(@database_to) + ';'
          + 'INSERT grp(group_name, arrival, departure, contact_id)'
          + 'SELECT @group_name, @arrival, @departure, @contact_id;'
          + 'SET @id = SCOPE_IDENTITY()';

          DECLARE @params NVARCHAR(MAX);
          SET @params = '@group_name CHAR(100),'
          + '@arrival DATETIME,'
          + '@departure DATETIME,'
          + '@contact_id CHAR(82),'
          + '@id INT OUTPUT';

          DECLARE @id INT;

          EXEC sp_executeSql @stmt = @sql_cmd
          , @params = @params
          , @group_name = @group_name
          , @arrival = @arrival
          , @departure = @departure
          , @contact_id = @contact_id
          , @id = @id OUTPUT;

          -- @id is now available to use
          END


          You can find more information about outputting a variable in the documentation for sp_executeSql.






          share|improve this answer

























            Your Answer








            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "182"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: false,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: null,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );













            draft saved

            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f233579%2finsert-to-a-table-from-a-database-to-other-same-sql-server-using-dynamic-sql%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            3














            Unless I am mistaken, your problem is not as complicated as you think. From what I understand, you want to take some data from your current database, store it in variables and then insert that into another database, returning the id that was inserted. If so, this will do what you need:



            CREATE PROCEDURE dbo.pr_consolidation_copy_group (
            @group_id numeric(10,0),
            @database_to varchar(100)
            )
            AS
            SET NOCOUNT ON;

            DECLARE @group_name char(100)
            ,@arrival datetime
            ,@departure datetime
            ,@contact_id char(82);

            SELECT @group_name = group_name ,
            @arrival = arrival,
            @departure = departure,
            @contact_id = contact_id
            FROM grp
            WHERE group_id = @group_id;

            DECLARE @sql_cmd NVARCHAR(MAX);
            SET @sql_cmd = 'USE ' + QUOTENAME(@database_to) + ';'
            + 'INSERT grp(group_name, arrival, departure, contact_id)'
            + 'SELECT @group_name, @arrival, @departure, @contact_id;'
            + 'SET @id = SCOPE_IDENTITY()';

            DECLARE @params NVARCHAR(MAX);
            SET @params = '@group_name CHAR(100),'
            + '@arrival DATETIME,'
            + '@departure DATETIME,'
            + '@contact_id CHAR(82),'
            + '@id INT OUTPUT';

            DECLARE @id INT;

            EXEC sp_executeSql @stmt = @sql_cmd
            , @params = @params
            , @group_name = @group_name
            , @arrival = @arrival
            , @departure = @departure
            , @contact_id = @contact_id
            , @id = @id OUTPUT;

            -- @id is now available to use
            END


            You can find more information about outputting a variable in the documentation for sp_executeSql.






            share|improve this answer





























              3














              Unless I am mistaken, your problem is not as complicated as you think. From what I understand, you want to take some data from your current database, store it in variables and then insert that into another database, returning the id that was inserted. If so, this will do what you need:



              CREATE PROCEDURE dbo.pr_consolidation_copy_group (
              @group_id numeric(10,0),
              @database_to varchar(100)
              )
              AS
              SET NOCOUNT ON;

              DECLARE @group_name char(100)
              ,@arrival datetime
              ,@departure datetime
              ,@contact_id char(82);

              SELECT @group_name = group_name ,
              @arrival = arrival,
              @departure = departure,
              @contact_id = contact_id
              FROM grp
              WHERE group_id = @group_id;

              DECLARE @sql_cmd NVARCHAR(MAX);
              SET @sql_cmd = 'USE ' + QUOTENAME(@database_to) + ';'
              + 'INSERT grp(group_name, arrival, departure, contact_id)'
              + 'SELECT @group_name, @arrival, @departure, @contact_id;'
              + 'SET @id = SCOPE_IDENTITY()';

              DECLARE @params NVARCHAR(MAX);
              SET @params = '@group_name CHAR(100),'
              + '@arrival DATETIME,'
              + '@departure DATETIME,'
              + '@contact_id CHAR(82),'
              + '@id INT OUTPUT';

              DECLARE @id INT;

              EXEC sp_executeSql @stmt = @sql_cmd
              , @params = @params
              , @group_name = @group_name
              , @arrival = @arrival
              , @departure = @departure
              , @contact_id = @contact_id
              , @id = @id OUTPUT;

              -- @id is now available to use
              END


              You can find more information about outputting a variable in the documentation for sp_executeSql.






              share|improve this answer



























                3












                3








                3







                Unless I am mistaken, your problem is not as complicated as you think. From what I understand, you want to take some data from your current database, store it in variables and then insert that into another database, returning the id that was inserted. If so, this will do what you need:



                CREATE PROCEDURE dbo.pr_consolidation_copy_group (
                @group_id numeric(10,0),
                @database_to varchar(100)
                )
                AS
                SET NOCOUNT ON;

                DECLARE @group_name char(100)
                ,@arrival datetime
                ,@departure datetime
                ,@contact_id char(82);

                SELECT @group_name = group_name ,
                @arrival = arrival,
                @departure = departure,
                @contact_id = contact_id
                FROM grp
                WHERE group_id = @group_id;

                DECLARE @sql_cmd NVARCHAR(MAX);
                SET @sql_cmd = 'USE ' + QUOTENAME(@database_to) + ';'
                + 'INSERT grp(group_name, arrival, departure, contact_id)'
                + 'SELECT @group_name, @arrival, @departure, @contact_id;'
                + 'SET @id = SCOPE_IDENTITY()';

                DECLARE @params NVARCHAR(MAX);
                SET @params = '@group_name CHAR(100),'
                + '@arrival DATETIME,'
                + '@departure DATETIME,'
                + '@contact_id CHAR(82),'
                + '@id INT OUTPUT';

                DECLARE @id INT;

                EXEC sp_executeSql @stmt = @sql_cmd
                , @params = @params
                , @group_name = @group_name
                , @arrival = @arrival
                , @departure = @departure
                , @contact_id = @contact_id
                , @id = @id OUTPUT;

                -- @id is now available to use
                END


                You can find more information about outputting a variable in the documentation for sp_executeSql.






                share|improve this answer















                Unless I am mistaken, your problem is not as complicated as you think. From what I understand, you want to take some data from your current database, store it in variables and then insert that into another database, returning the id that was inserted. If so, this will do what you need:



                CREATE PROCEDURE dbo.pr_consolidation_copy_group (
                @group_id numeric(10,0),
                @database_to varchar(100)
                )
                AS
                SET NOCOUNT ON;

                DECLARE @group_name char(100)
                ,@arrival datetime
                ,@departure datetime
                ,@contact_id char(82);

                SELECT @group_name = group_name ,
                @arrival = arrival,
                @departure = departure,
                @contact_id = contact_id
                FROM grp
                WHERE group_id = @group_id;

                DECLARE @sql_cmd NVARCHAR(MAX);
                SET @sql_cmd = 'USE ' + QUOTENAME(@database_to) + ';'
                + 'INSERT grp(group_name, arrival, departure, contact_id)'
                + 'SELECT @group_name, @arrival, @departure, @contact_id;'
                + 'SET @id = SCOPE_IDENTITY()';

                DECLARE @params NVARCHAR(MAX);
                SET @params = '@group_name CHAR(100),'
                + '@arrival DATETIME,'
                + '@departure DATETIME,'
                + '@contact_id CHAR(82),'
                + '@id INT OUTPUT';

                DECLARE @id INT;

                EXEC sp_executeSql @stmt = @sql_cmd
                , @params = @params
                , @group_name = @group_name
                , @arrival = @arrival
                , @departure = @departure
                , @contact_id = @contact_id
                , @id = @id OUTPUT;

                -- @id is now available to use
                END


                You can find more information about outputting a variable in the documentation for sp_executeSql.







                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited 1 hour ago

























                answered 2 hours ago









                Mr.BrownstoneMr.Brownstone

                9,75232342




                9,75232342



























                    draft saved

                    draft discarded
















































                    Thanks for contributing an answer to Database Administrators Stack Exchange!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f233579%2finsert-to-a-table-from-a-database-to-other-same-sql-server-using-dynamic-sql%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Isabella Eugénie Boyer Biographie | Références | Menu de navigationmodifiermodifier le codeComparator to Compute the Relative Value of a U.S. Dollar Amount – 1774 to Present.

                    Join wedge with single bond in chemfigHow to make only one part of double bond bold with chemfig?Crossing bonds in chemfigjoining atoms in chemfig. Two adjacent molculesHow do I selectively change bond length in chemfig?Ugly bond joints in chemfigchemfig: reaction above arrowUsing the mhchem and chemfig packages in conjunctionBonding to specific element letter using chemfigResonance hybrids in chemfigScale chemfig molecule in beamer with tikzWhy does this chemfig bond with a hook start in the middle of the atom?

                    Are small insurances worth itIs insurance worth it if you can afford to replace the item? If not, when is it?Is accident insurance worth it for my kids who play sportsIs insuring property for more than it is worth allowed?At what point does it become worth it to file an insurance claim?Are wage loss insurance programs worth the cost compared to having an emergency fund?When is an event worth insuring against?Is insurance worth it if you can afford to replace the item? If not, when is it?FHA loan just commenced : Any way to get any of the up-front mortgage insurance back?Which types of insurances do I need to buy?Should I carry less renter's insurance if I can self-insure?Mortgage Adviser Signed Me Up For Multiple Home and Life Insurances (UK)Why many travel insurances don't cover country of nationality?