Udostępnij przez


TrackingProfile.Version Właściwość

Definicja

Pobiera lub ustawia wersję profilu śledzenia.

public:
 property Version ^ Version { Version ^ get(); void set(Version ^ value); };
public Version Version { get; set; }
member this.Version : Version with get, set
Public Property Version As Version

Wartość właściwości

Element Version z .TrackingProfile

Przykłady

W poniższym przykładzie kodu pokazano, jak utworzyć TrackingProfile obiekt przy użyciu TrackingProfile konstruktora i użyć właściwości obiektu, aby ułatwić śledzenie wykonywania przepływu pracy. Przykładowy kod używa ActivityTrackPointswłaściwości , Versioni WorkflowTrackPoints .

Ten przykładowy kod jest częścią zapytania korzystającego z przykładu zestawu SQLTrackingService SDK z pliku Program.cs. Aby uzyskać więcej informacji, zobacz Query Using SQLTrackingService (Wykonywanie zapytań przy użyciu usługi SQLTrackingService).

private static void CreateAndInsertTrackingProfile()
{
    TrackingProfile profile = new TrackingProfile();
    ActivityTrackPoint activityTrack = new ActivityTrackPoint();
    ActivityTrackingLocation activityLocation = new ActivityTrackingLocation(typeof(Activity));
    activityLocation.MatchDerivedTypes = true;
    IEnumerable<ActivityExecutionStatus> statuses = Enum.GetValues(typeof(ActivityExecutionStatus)) as IEnumerable<ActivityExecutionStatus>;
    foreach (ActivityExecutionStatus status in statuses)
    {
        activityLocation.ExecutionStatusEvents.Add(status);
    }

    activityTrack.MatchingLocations.Add(activityLocation);
    profile.ActivityTrackPoints.Add(activityTrack);
    profile.Version = version;

    WorkflowTrackPoint workflowTrack = new WorkflowTrackPoint();
    WorkflowTrackingLocation workflowLocation = new WorkflowTrackingLocation();
    IEnumerable<TrackingWorkflowEvent> eventStatuses = Enum.GetValues(typeof(TrackingWorkflowEvent)) as IEnumerable<TrackingWorkflowEvent>;
    foreach (TrackingWorkflowEvent status in eventStatuses)
    {
        workflowLocation.Events.Add(status);
    }

    workflowTrack.MatchingLocation = workflowLocation;
    profile.WorkflowTrackPoints.Add(workflowTrack);

    TrackingProfileSerializer serializer = new TrackingProfileSerializer();
    StringWriter writer = new StringWriter(new StringBuilder(), CultureInfo.InvariantCulture);
    serializer.Serialize(writer, profile);
    string trackingprofile = writer.ToString();
    InsertTrackingProfile(trackingprofile);
}
Shared Sub CreateAndInsertTrackingProfile()
    Dim profile As TrackingProfile = New TrackingProfile()

    Dim activityTrack As ActivityTrackPoint = New ActivityTrackPoint()
    Dim activityLocation As ActivityTrackingLocation = New ActivityTrackingLocation(GetType(Activity))
    activityLocation.MatchDerivedTypes = True
    Dim statuses As IEnumerable(Of ActivityExecutionStatus) = CType(System.Enum.GetValues(GetType(ActivityExecutionStatus)), IEnumerable(Of ActivityExecutionStatus))
    For Each status As ActivityExecutionStatus In statuses
        activityLocation.ExecutionStatusEvents.Add(status)
    Next

    activityTrack.MatchingLocations.Add(activityLocation)
    profile.ActivityTrackPoints.Add(activityTrack)
    profile.Version = version

    Dim workflowTrack As WorkflowTrackPoint = New WorkflowTrackPoint()
    Dim workflowLocation As WorkflowTrackingLocation = New WorkflowTrackingLocation()
    Dim eventStatuses As IEnumerable(Of TrackingWorkflowEvent) = CType(System.Enum.GetValues(GetType(TrackingWorkflowEvent)), IEnumerable(Of TrackingWorkflowEvent))
    For Each status As TrackingWorkflowEvent In eventStatuses
        workflowLocation.Events.Add(status)
    Next

    workflowTrack.MatchingLocation = workflowLocation
    profile.WorkflowTrackPoints.Add(workflowTrack)

    Dim serializer As TrackingProfileSerializer = New TrackingProfileSerializer()
    Dim writer As StringWriter = New StringWriter(New StringBuilder(), CultureInfo.InvariantCulture)
    serializer.Serialize(writer, profile)
    Dim trackingProfile As String = writer.ToString()
    InsertTrackingProfile(trackingProfile)
End Sub

Uwagi

Ze względu na semantyka buforowania profilów w a aparatu środowiska uruchomieniowego przepływu pracy, jeśli zmienisz zawartość elementu TrackingProfile , musisz zaktualizować Versionelement . Jeśli tego nie zrobisz, aktualizacja TrackingProfile może nie zostać załadowana przez aparat środowiska uruchomieniowego przepływu pracy, nawet jeśli zostanie zwrócona przez wywołanie metody TrackingService.TryReloadProfilelub wysłana w ProfileUpdatedEventArgs skojarzonym ze zdarzeniem ProfileUpdated . W związku z tym, aby upewnić się, że zaktualizowany TrackingProfile jest ładowany przez aparat środowiska uruchomieniowego przepływu pracy, należy zmienić parametr Version dla elementu TrackingProfile. Następnie można jawnie wywołać WorkflowInstance.ReloadTrackingProfiles dowolne odpowiednie wystąpienia przepływu pracy lub, w zależności od implementacji, możesz polegać na usłudze śledzenia, aby poinformować aparat środowiska uruchomieniowego przepływu pracy o zmianie. Aby uzyskać więcej informacji, zobacz TrackingService.

Dotyczy

Zobacz też