OperationBehaviorAttribute.TransactionScopeRequired Eigenschap

Definitie

Hiermee wordt een waarde opgehaald of ingesteld die aangeeft of voor de methode een transactiebereik is vereist voor de uitvoering ervan.

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

Waarde van eigenschap

true als voor de methode een transactiebereik is vereist om uit te voeren; anders, false. De standaardwaarde is false.

Voorbeelden

In het volgende codevoorbeeld ziet u een bewerking die wordt uitgevoerd binnen een verplichte gedistribueerde transactie. De TransactionScopeRequired eigenschap geeft aan dat de bewerking wordt uitgevoerd onder een transactiebereik en de TransactionAutoComplete eigenschap aangeeft dat als er geen onverwerkte uitzonderingen optreden, het transactiebereik automatisch wordt voltooid. Als er een niet-verwerkte uitzondering optreedt, wordt de transactie afgebroken.

using System;
using System.ServiceModel;
using System.Transactions;

namespace Microsoft.WCF.Documentation
{
  [ServiceContract(Namespace="http://microsoft.wcf.documentation", SessionMode=SessionMode.Required)]
  public interface IBehaviorService
  {
    [OperationContract]
    string TxWork(string message);
  }

  // Note: To use the TransactionIsolationLevel property, you
  // must add a reference to the System.Transactions.dll assembly.
  /* The following service implementation:
   *   -- Processes messages on one thread at a time
   *   -- Creates one service object per session
   *   -- Releases the service object when the transaction commits
   */
  [ServiceBehavior(
    ConcurrencyMode=ConcurrencyMode.Single,
    InstanceContextMode=InstanceContextMode.PerSession,
    ReleaseServiceInstanceOnTransactionComplete=true
  )]
  public class BehaviorService : IBehaviorService, IDisposable
  {
    Guid myID;

    public BehaviorService()
    {
      myID = Guid.NewGuid();
      Console.WriteLine(
        "Object "
        + myID.ToString()
        + " created.");
    }

    /*
     * The following operation-level behaviors are specified:
     *   -- Always executes under a transaction scope.
     *   -- The transaction scope is completed when the operation terminates
     *       without an unhandled exception.
     */
    [OperationBehavior(
      TransactionAutoComplete = true,
      TransactionScopeRequired = true
    )]
    [TransactionFlow(TransactionFlowOption.Mandatory)]
    public string TxWork(string message)
    {
      // Do some transactable work.
      Console.WriteLine("TxWork called with: " + message);
      // Display transaction information.

      TransactionInformation info = Transaction.Current.TransactionInformation;
      Console.WriteLine("The distributed tx ID: {0}.", info.DistributedIdentifier);
      Console.WriteLine("The tx status: {0}.", info.Status);
      return String.Format("Hello. This was object {0}.",myID.ToString()) ;
    }

    public void Dispose()
    {
      Console.WriteLine(
        "Service "
        + myID.ToString()
        + " is being recycled."
      );
    }
  }
}
Imports System.ServiceModel
Imports System.Transactions

Namespace Microsoft.WCF.Documentation
  <ServiceContract(Namespace:="http://microsoft.wcf.documentation", SessionMode:=SessionMode.Required)> _
  Public Interface IBehaviorService
    <OperationContract> _
    Function TxWork(ByVal message As String) As String
  End Interface

    ' Note: To use the TransactionIsolationLevel property, you 
    ' must add a reference to the System.Transactions.dll assembly.
    ' The following service implementation:
    '   *   -- Processes messages on one thread at a time
    '   *   -- Creates one service object per session
    '   *   -- Releases the service object when the transaction commits

    <ServiceBehavior(ConcurrencyMode:=ConcurrencyMode.Single, InstanceContextMode:=InstanceContextMode.PerSession, _
                     ReleaseServiceInstanceOnTransactionComplete:=True)> _
    Public Class BehaviorService
        Implements IBehaviorService, IDisposable
        Private myID As Guid

        Public Sub New()
            myID = Guid.NewGuid()
            Console.WriteLine("Object " & myID.ToString() & " created.")
        End Sub

        '    
        '     * The following operation-level behaviors are specified:
        '     *   -- Always executes under a transaction scope.
        '     *   -- The transaction scope is completed when the operation terminates 
        '     *       without an unhandled exception.
        '     
        <OperationBehavior(TransactionAutoComplete:=True, TransactionScopeRequired:=True), _
        TransactionFlow(TransactionFlowOption.Mandatory)> _
        Public Function TxWork(ByVal message As String) As String Implements IBehaviorService.TxWork
            ' Do some transactable work.
            Console.WriteLine("TxWork called with: " & message)
            ' Display transaction information.

            Dim info As TransactionInformation = Transaction.Current.TransactionInformation
            Console.WriteLine("The distributed tx ID: {0}.", info.DistributedIdentifier)
            Console.WriteLine("The tx status: {0}.", info.Status)
            Return String.Format("Hello. This was object {0}.", myID.ToString())
        End Function

        Public Sub Dispose() Implements IDisposable.Dispose
            Console.WriteLine("Service " & myID.ToString() & " is being recycled.")
        End Sub
    End Class
End Namespace

Opmerkingen

Stel de opdracht TransactionScopeRequired in om true te vereisen dat uw bewerking wordt uitgevoerd binnen een transactiebereik. Als er een gestroomde transactie beschikbaar is, wordt de bewerking binnen die transactie uitgevoerd. Als er geen transactie beschikbaar is, wordt er een nieuwe transactie gemaakt en gebruikt voor de uitvoering van de bewerking. De binding die is opgegeven in het eindpunt bepaalt of stromende transacties worden ondersteund. Om het juiste gedrag te verkrijgen, moet u de interactie begrijpen tussen de vraag of transactiestroom is toegestaan door de binding en de TransactionScopeRequired eigenschap. In de volgende tabel ziet u het mogelijke gedrag.

TransactieScopeVereist Binding staat transactiestroom toe Transactie van bellerstromen Resultaat
Onwaar Onwaar No De methode wordt uitgevoerd zonder een transactie.
True Onwaar No De methode maakt en voert deze uit binnen een nieuwe transactie.
Waar of onwaar Onwaar Ja Er wordt een SOAP-fout geretourneerd voor de transactieheader.
Onwaar True Ja De methode wordt uitgevoerd zonder een transactie.
True True Ja De methode wordt uitgevoerd onder de gestroomde transactie.

Van toepassing op