Moving tables between filegroups

  • I am working on a ssis package. Tables created in the SSIS are named in the MMYY format using the datepart function. I need to determine the year of the table and then put it in a filegroup accordingly. Like tables with '07' in the name will go in a 07 filegroup.

    I can query the database and get a list of tables for 07

    I am thinking placing them in yearly filegroups can be done in 2 ways

    1.I can place the table in filegroup using the ‘ON’ clause using a variable (containing the current year) when I create the table. This is not working when I try using the variable below it creates a filegroup by the name ‘@fileg’.

    declare @fileg varchar(60)

    set @fileg = substring(CONVERT(VARCHAR, DATEPART(YEAR, GETDATE())), 3, 4)

    create table test (id int) ON [@fileg]

    2.I can create a bunch of filegroups and have a step in the package where a query can be used to identify tables with ‘06’, ‘07’ and so on and then place them in the required filegroups. I found one way was to use the 'drop constraint move with' option but that is working with primary key but not with check constraint

    That is all the info i have been able to get so far. Does Please help. Are there any other ways of doing in besides an execute SQL Task in SSIS?

  • You need to use dynamic SQL. Something like this:

    declare @fileg varchar(60), @sql varchar(500)

    set @fileg = substring(CONVERT(VARCHAR, DATEPART(YEAR, GETDATE())), 3, 4)

    Set @sql = 'create table dbo.test (id int) ON [' + @fileg + ']'

    Exec(@Sql)

    ******************
    Dinakar Nethi
    Life is short. Enjoy it.
    ******************

  • Thankyou for your help.. i tried using dynamic sql for creating a filegroup as a task in the beginning of the package but that is giving me an error now..could you plz give me some kind of direction on how i can solve this:

    declare @newfilegroup varchar(60)

    set @newfilegroup = substring(CONVERT(VARCHAR, DATEPART(YEAR, GETDATE())), 3, 4)

    EXEC ('ALTER DATABASE test ADD FILEGROUP ' + @newfilegroup)

    this gives me a synatx error where as

    declare @newfilegroup varchar(60)

    set @newfilegroup = 'a' + substring(CONVERT(VARCHAR, DATEPART(YEAR, GETDATE())), 3, 4)

    EXEC ('ALTER DATABASE test ADD FILEGROUP ' + @newfilegroup)

    works fine

Viewing 3 posts - 1 through 2 (of 2 total)

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