SqlWorkflowInstanceStore.Promote Method (String, IEnumerable<XName>, IEnumerable<XName>)

.NET Framework (current version)

The .NET API Reference documentation has a new home. Visit the .NET API Browser on docs.microsoft.com to see the new experience.

Associates the specified properties with a workflow instance so that you can query for instances based on specific values for these properties. These properties that can be used in external queries can be of simple types (for example: Int64, String, and so on) or of a serialized binary type (byte[]). Binary properties are typically used to store tracking data.

Namespace:   System.Activities.DurableInstancing
Assembly:  System.Activities.DurableInstancing (in System.Activities.DurableInstancing.dll)

member Promote : 
        name:string *
        promoteAsVariant:IEnumerable<XName> *
        promoteAsBinary:IEnumerable<XName> -> unit


Type: System.String

The name of the promotion itself.

Type: System.Collections.Generic.IEnumerable<XName>

The properties that must be promoted as variants.

Type: System.Collections.Generic.IEnumerable<XName>

The properties that must be promoted as a binary stream.

The following code sample demonstrates using Promote in a SqlWorkflowInstanceStore. This example is from the SQLStoreExtensibility sample.

static void Main(string[] args)
    // Create service host.
    WorkflowServiceHost host = new WorkflowServiceHost(CountingWorkflow(), new Uri(hostBaseAddress));

    // Add service endpoint.
    host.AddServiceEndpoint("ICountingWorkflow", new BasicHttpBinding(), "");

    // Define SqlWorkflowInstanceStore and assign it to host.
    SqlWorkflowInstanceStoreBehavior store = new SqlWorkflowInstanceStoreBehavior(connectionString);
    List<XName> variantProperties = new List<XName>()
    store.Promote("CountStatus", variantProperties, null);


    host.WorkflowExtensions.Add<CounterStatus>(() => new CounterStatus());
    host.Open(); // This sample needs to be run with Admin privileges.
                 // Otherwise the channel listener is not allowed to open ports.
                 // See sample documentation for details.

    // Create a client that sends a message to create an instance of the workflow.
    ICountingWorkflow client = ChannelFactory<ICountingWorkflow>.CreateChannel(new BasicHttpBinding(), new EndpointAddress(hostBaseAddress));

    Console.WriteLine("(Press [Enter] at any time to terminate host)");

.NET Framework
Available since 4.0
Return to top