Renaming logical names with variables












1















I'm trying to rename files logical names with variable. The problem is not the query in variable @ndfnameold, because if I put the simple string, i'll get same error.



DECLARE @ndfnameold Nvarchar(MAX)
SET @ndfnameold = (SELECT name from [sys].[database_files] where physical_name like '%ndf')
DECLARE @query varchar(MAX)

SET @query = 'ALTER DATABASE [MYDATABASE] MODIFY FILE ( NAME = '+ @ndfnameold +', NEWNAME = MYDATABASE_1_Data )'

EXEC(@query)


Msg 102, Level 15, State 1, Line 1
Incorrect syntax near '-'.



I don't get whats wrong with this. SQL Server 2017










share|improve this question





























    1















    I'm trying to rename files logical names with variable. The problem is not the query in variable @ndfnameold, because if I put the simple string, i'll get same error.



    DECLARE @ndfnameold Nvarchar(MAX)
    SET @ndfnameold = (SELECT name from [sys].[database_files] where physical_name like '%ndf')
    DECLARE @query varchar(MAX)

    SET @query = 'ALTER DATABASE [MYDATABASE] MODIFY FILE ( NAME = '+ @ndfnameold +', NEWNAME = MYDATABASE_1_Data )'

    EXEC(@query)


    Msg 102, Level 15, State 1, Line 1
    Incorrect syntax near '-'.



    I don't get whats wrong with this. SQL Server 2017










    share|improve this question



























      1












      1








      1








      I'm trying to rename files logical names with variable. The problem is not the query in variable @ndfnameold, because if I put the simple string, i'll get same error.



      DECLARE @ndfnameold Nvarchar(MAX)
      SET @ndfnameold = (SELECT name from [sys].[database_files] where physical_name like '%ndf')
      DECLARE @query varchar(MAX)

      SET @query = 'ALTER DATABASE [MYDATABASE] MODIFY FILE ( NAME = '+ @ndfnameold +', NEWNAME = MYDATABASE_1_Data )'

      EXEC(@query)


      Msg 102, Level 15, State 1, Line 1
      Incorrect syntax near '-'.



      I don't get whats wrong with this. SQL Server 2017










      share|improve this question
















      I'm trying to rename files logical names with variable. The problem is not the query in variable @ndfnameold, because if I put the simple string, i'll get same error.



      DECLARE @ndfnameold Nvarchar(MAX)
      SET @ndfnameold = (SELECT name from [sys].[database_files] where physical_name like '%ndf')
      DECLARE @query varchar(MAX)

      SET @query = 'ALTER DATABASE [MYDATABASE] MODIFY FILE ( NAME = '+ @ndfnameold +', NEWNAME = MYDATABASE_1_Data )'

      EXEC(@query)


      Msg 102, Level 15, State 1, Line 1
      Incorrect syntax near '-'.



      I don't get whats wrong with this. SQL Server 2017







      sql-server tsql






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 13 '18 at 15:08









      a_horse_with_no_name

      296k46451546




      296k46451546










      asked Nov 13 '18 at 14:42









      atr4statr4st

      82




      82
























          1 Answer
          1






          active

          oldest

          votes


















          3














          Since there's no - in the rest of your SQL, we can infer that there is one in the old logical file name. Since - isn't an allowed character for a Regular Identifier, we'll have to delimit it.



          Safest is to use the QUOTENAME function that will delimit the name whilst respecting escaping rules if other characters are also problematic:



          SET @query = 'ALTER DATABASE [MYDATABASE] MODIFY FILE ( NAME = ' +
          QUOTENAME(@ndfnameold) +
          ', NEWNAME = MYDATABASE_1_Data )'





          share|improve this answer
























          • Thanks for the answering. Yes, there is - in the old logical file name. I tried to use QUOTENAME() as you posted but still the same error message. Msg 102, Level 15, State 1, Line 1 Incorrect syntax near '-'.

            – atr4st
            Nov 14 '18 at 6:19











          Your Answer






          StackExchange.ifUsing("editor", function () {
          StackExchange.using("externalEditor", function () {
          StackExchange.using("snippets", function () {
          StackExchange.snippets.init();
          });
          });
          }, "code-snippets");

          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "1"
          };
          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: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          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%2fstackoverflow.com%2fquestions%2f53283472%2frenaming-logical-names-with-variables%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














          Since there's no - in the rest of your SQL, we can infer that there is one in the old logical file name. Since - isn't an allowed character for a Regular Identifier, we'll have to delimit it.



          Safest is to use the QUOTENAME function that will delimit the name whilst respecting escaping rules if other characters are also problematic:



          SET @query = 'ALTER DATABASE [MYDATABASE] MODIFY FILE ( NAME = ' +
          QUOTENAME(@ndfnameold) +
          ', NEWNAME = MYDATABASE_1_Data )'





          share|improve this answer
























          • Thanks for the answering. Yes, there is - in the old logical file name. I tried to use QUOTENAME() as you posted but still the same error message. Msg 102, Level 15, State 1, Line 1 Incorrect syntax near '-'.

            – atr4st
            Nov 14 '18 at 6:19
















          3














          Since there's no - in the rest of your SQL, we can infer that there is one in the old logical file name. Since - isn't an allowed character for a Regular Identifier, we'll have to delimit it.



          Safest is to use the QUOTENAME function that will delimit the name whilst respecting escaping rules if other characters are also problematic:



          SET @query = 'ALTER DATABASE [MYDATABASE] MODIFY FILE ( NAME = ' +
          QUOTENAME(@ndfnameold) +
          ', NEWNAME = MYDATABASE_1_Data )'





          share|improve this answer
























          • Thanks for the answering. Yes, there is - in the old logical file name. I tried to use QUOTENAME() as you posted but still the same error message. Msg 102, Level 15, State 1, Line 1 Incorrect syntax near '-'.

            – atr4st
            Nov 14 '18 at 6:19














          3












          3








          3







          Since there's no - in the rest of your SQL, we can infer that there is one in the old logical file name. Since - isn't an allowed character for a Regular Identifier, we'll have to delimit it.



          Safest is to use the QUOTENAME function that will delimit the name whilst respecting escaping rules if other characters are also problematic:



          SET @query = 'ALTER DATABASE [MYDATABASE] MODIFY FILE ( NAME = ' +
          QUOTENAME(@ndfnameold) +
          ', NEWNAME = MYDATABASE_1_Data )'





          share|improve this answer













          Since there's no - in the rest of your SQL, we can infer that there is one in the old logical file name. Since - isn't an allowed character for a Regular Identifier, we'll have to delimit it.



          Safest is to use the QUOTENAME function that will delimit the name whilst respecting escaping rules if other characters are also problematic:



          SET @query = 'ALTER DATABASE [MYDATABASE] MODIFY FILE ( NAME = ' +
          QUOTENAME(@ndfnameold) +
          ', NEWNAME = MYDATABASE_1_Data )'






          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 13 '18 at 14:49









          Damien_The_UnbelieverDamien_The_Unbeliever

          194k17248335




          194k17248335













          • Thanks for the answering. Yes, there is - in the old logical file name. I tried to use QUOTENAME() as you posted but still the same error message. Msg 102, Level 15, State 1, Line 1 Incorrect syntax near '-'.

            – atr4st
            Nov 14 '18 at 6:19



















          • Thanks for the answering. Yes, there is - in the old logical file name. I tried to use QUOTENAME() as you posted but still the same error message. Msg 102, Level 15, State 1, Line 1 Incorrect syntax near '-'.

            – atr4st
            Nov 14 '18 at 6:19

















          Thanks for the answering. Yes, there is - in the old logical file name. I tried to use QUOTENAME() as you posted but still the same error message. Msg 102, Level 15, State 1, Line 1 Incorrect syntax near '-'.

          – atr4st
          Nov 14 '18 at 6:19





          Thanks for the answering. Yes, there is - in the old logical file name. I tried to use QUOTENAME() as you posted but still the same error message. Msg 102, Level 15, State 1, Line 1 Incorrect syntax near '-'.

          – atr4st
          Nov 14 '18 at 6:19


















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Stack Overflow!


          • 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%2fstackoverflow.com%2fquestions%2f53283472%2frenaming-logical-names-with-variables%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

          Full-time equivalent

          Bicuculline

          さくらももこ