0

ワークフロー内のあるアクションから別のアクションにカスタム変数タイプを渡しています。カスタムオブジェクトの定義は次のとおりです

       public class ConfigDatabase
        {
            public string Name;
            public string Host;
            public string Port;
            public string Instance;
            public string User;
            public string Password;
        }

        public class ConfigDatabases
        {
            public string DatabaseToUse;
            public List<ConfigDatabase> DatabaseList;

            public ConfigDatabases()
            {
                DatabaseList = new List<ConfigDatabase>();
            }
        }

        public class ConfigEnvironment
        {
            public ConfigDatabases EnvironmentConfigDatabase;

            public ConfigEnvironment()
            {
                EnvironmentConfigDatabase = new ConfigDatabases();
            }

            public ConfigDatabase ReturnDatabaseInfo()
            {
                ConfigDatabase ConfigDatabaseInfo = new ConfigDatabase();
                for (int Count1 = 0; Count1 < EnvironmentConfigDatabase.DatabaseList.Count; Count1++)
                {
                    if (EnvironmentConfigDatabase.DatabaseList[Count1].Name == EnvironmentConfigDatabase.DatabaseToUse)
                    {
                        ConfigDatabaseInfo = EnvironmentConfigDatabase.DatabaseList[Count1];
                        return ConfigDatabaseInfo;
                    }
                }
                return ConfigDatabaseInfo;
            }

            public string GetDatabaseConnectionString()
            {
                ConfigDatabase DatabaseInfo = ReturnDatabaseInfo();
                string ConnectionString = "Data Source=(description=(address=(protocol=tcp)(host=" + DatabaseInfo.Host + ")(port=" + DatabaseInfo.Port + "))(connect_data=(sid=" + DatabaseInfo.Instance + ")));User ID=" + DatabaseInfo.User + ";Password=" + DatabaseInfo.Password + ";";
                return ConnectionString;
            }
        }

アクションの最初のステップで、次のコードを実行してファイルから構成データをロードし、関数 Execute で返されるオブジェクト (ConfigEnvironment) に格納します。

public sealed class InitializeEnvironment : CodeActivity<ConfigEnvironment>
{
    // Define an activity input argument of type string
    public InArgument<string> EnvironmentFileLocation { get; set; }

    // If your activity returns a value, derive from CodeActivity<TResult>
    // and return the value from the Execute method.
    protected override ConfigEnvironment Execute(CodeActivityContext context)
    {
        // Obtain the runtime value of the Text input argument
        string EnvironmentFile = context.GetValue(this.EnvironmentFileLocation);
        EnvironmentConfigInitialization EnvironmentInitialize = new EnvironmentConfigInitialization(EnvironmentFile);
        ConfigEnvironment EnvironmentDetail = EnvironmentInitialize.LoadData();
        return EnvironmentDetail;
    }
}

ワークフローの後続のアクティビティで、このオブジェクトに格納されているデータを取得したいと考えています。ただし、EnvironmentDetail オブジェクトが関数 GetDatabaseConnectionString を見つけられなかったため、次のコードではコンパイル エラーが発生します。

public sealed class ExecuteSQL : CodeActivity<DataRowCollection>
{
    // Define an activity input argument of type string
    public InArgument<string> SQLScript { get; set; }
    public InArgument<ConfigEnvironment> EnvironmentDetail { get; set; }

    // If your activity returns a value, derive from CodeActivity<TResult>
    // and return the value from the Execute method.
    protected override DataRowCollection Execute(CodeActivityContext context)
    {

        string connectionString4 = EnvironmentDetail.GetDatabaseConnectionString(); //This create a compile error

}

}

コンパイルの警告は次のとおりです。'System.Activities.InArgument' には 'GetDatabaseConnectionString' の定義が含まれておらず、'System.Activities.InArgument' 型の最初の引数を受け入れる拡張メソッド 'GetDatabaseConnectionString' が見つかりませんでした (ディレクティブまたはアセンブリ参照を使用していますか?)

4

1 に答える 1

0

結局のところ、EnvironmentDetailは Type InArgument(またはInArgument<ConfigEnvironment>) ですが、Type ではありません。 Type の変数を取得するConfigEnvironment には、 a を実行する必要があります。context.Get<ConfigEnvironment>()ConfigEnvironment

これで問題が解決するかどうか、またはまだ何か問題がある場合はお知らせください;-)

于 2013-03-14T20:53:11.197 に答える