Использование библиотеки SMO ​​в SSIS 2008

Добрый день,

У меня возникли некоторые проблемы при написании простого скрипта с использованием объектов SMO в C#, чтобы проверить, существует ли объект, а затем создать его. Этот код находится в компоненте задачи сценария в службах SSIS. Код выполняется успешно, однако новая база данных не отображается на моем локальном экземпляре. Любая помощь будет принята с благодарностью.

using System;
using System.Data;
using Microsoft.SqlServer.Dts.Runtime;
using System.Windows.Forms;
using System.Collections;
using System.Data.SqlClient;
using Microsoft.SqlServer.Management.Common;
using Microsoft.SqlServer.Management.Smo;

        public void Main()
        {
            //String DBName = Dts.Variables["TmpViewDBName"].Value.ToString();
            //String Instance = Dts.Variables["TmpViewDBInstance"].Value.ToString();

            String DBName = "localhost";
            String Instance = "TmpViewDB";

            Server TmpViewServer = new Server(Instance);

            //Windows Auth
            TmpViewServer.ConnectionContext.LoginSecure = true;
            TmpViewServer.ConnectionContext.Connect();

            if (TmpViewServer.Databases[DBName] != null)
            {
                TmpViewServer.Databases[DBName].Drop();
            }

            Database TmpViewDB = new Database(TmpViewServer, DBName);

            if (TmpViewServer.ConnectionContext.IsOpen)

                    TmpViewServer.ConnectionContext.Disconnect();

            Dts.TaskResult = (int)ScriptResults.Success;
        }

1 ответ

Я считаю, что вам нужно добавить строку, чтобы фактически создать объект. В настоящее время вы только создали экземпляр объекта, но на самом деле никогда не обращались к базе данных для создания удаленного объекта.

    Database TmpViewDB = new Database(TmpViewServer, DBName);
    TmpViewDB.Create();
Другие вопросы по тегам