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?

What steps are necessary to read a Modern SSD in Medieval Europe?

Break Away Valves for Launch

Is wanting to ask what to write an indication that you need to change your story?

Some questions about different axiomatic systems for neighbourhoods

Why, when going from special to general relativity, do we just replace partial derivatives with covariant derivatives?

Are police here, aren't itthey?

How did people program for Consoles with multiple CPUs?

How to count occurrences of text in a file?

Why doesn't UK go for the same deal Japan has with EU to resolve Brexit?

is it ok to reduce charging current for li ion 18650 battery?

Is this "being" usage is essential?

How to get from Geneva Airport to Metabief?

Can MTA send mail via a relay without being told so?

Help understanding this unsettling image of Titan, Epimetheus, and Saturn's rings?

Is there a way to save my career from absolute disaster?

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

How do I align (1) and (2)?

Which one is the true statement?

What does "Its cash flow is deeply negative" mean?

unclear about Dynamic Binding

A Man With a Stainless Steel Endoskeleton (like The Terminator) Fighting Cloaked Aliens Only He Can See

Newlines in BSD sed vs gsed

Domestic-to-international connection at Orlando (MCO)

Why is information "lost" when it got into a black hole?



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 4 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

                    Are there any AGPL-style licences that require source code modifications to be public? Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?Force derivative works to be publicAre there any GPL like licenses for Apple App Store?Do you violate the GPL if you provide source code that cannot be compiled?GPL - is it distribution to use libraries in an appliance loaned to customers?Distributing App for free which uses GPL'ed codeModifications of server software under GPL, with web/CLI interfaceDoes using an AGPLv3-licensed library prevent me from dual-licensing my own source code?Can I publish only select code under GPLv3 from a private project?Is there published precedent regarding the scope of covered work that uses AGPL software?If MIT licensed code links to GPL licensed code what should be the license of the resulting binary program?If I use a public API endpoint that has its source code licensed under AGPL in my app, do I need to disclose my source?

                    2013 GY136 Descoberta | Órbita | Referências Menu de navegação«List Of Centaurs and Scattered-Disk Objects»«List of Known Trans-Neptunian Objects»

                    Button changing it's text & action. Good or terrible? The 2019 Stack Overflow Developer Survey Results Are Inchanging text on user mouseoverShould certain functions be “hard to find” for powerusers to discover?Custom liking function - do I need user login?Using different checkbox style for different checkbox behaviorBest Practices: Save and Exit in Software UIInteraction with remote validated formMore efficient UI to progress the user through a complicated process?Designing a popup notice for a gameShould bulk-editing functions be hidden until a table row is selected, or is there a better solution?Is it bad practice to disable (replace) the context menu?