OperationBehaviorAttribute.TransactionScopeRequired Özellik
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Yönteminin yürütülmesi için bir işlem kapsamı gerekip gerekmediğini belirten bir değer alır veya ayarlar.
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
Özellik Değeri
true
yöntemi yürütülecek bir işlem kapsamı gerektiriyorsa; aksi takdirde , false
. Varsayılan değer: false
.
Örnekler
Aşağıdaki kod örneği, zorunlu dağıtılmış bir işlem içinde yürütülen bir işlemi gösterir. TransactionScopeRequired özelliği işlemin bir işlem kapsamı altında yürütüldüğünü, TransactionAutoComplete özelliği ise işlenmeyen özel durum oluşmazsa işlem kapsamının otomatik olarak tamamlandığını gösterir. İşlenmeyen bir özel durum oluşursa işlem durdurulür.
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
Açıklamalar
değerini TransactionScopeRequiredtrue
, işleminizin bir işlem kapsamında yürütülmesini gerektirecek şekilde ayarlayın. Akışlı bir işlem varsa, işlem bu işlem içinde yürütülür. Kullanılabilir bir işlem yoksa, yeni bir işlem oluşturulur ve işlem yürütmesi için kullanılır. Uç noktada belirtilen bağlama, akışlı işlemlerin desteklenip desteklenmediğini denetler. Bu nedenle, uygun davranışı elde etmek için bağlama ve TransactionScopeRequired özellik tarafından işlem akışına izin verilip verilmeyeceğini arasındaki etkileşimi anlamanız gerekir. Aşağıdaki tabloda olası davranış gösterilmektedir.
Transactionscoperequired | Bağlama işlem akışına izin verir | Çağıran akış işlemi | Sonuç |
---|---|---|---|
Yanlış | Yanlış | Hayır | Yöntem işlem olmadan yürütülür. |
Doğru | Yanlış | Hayır | Yöntem, yeni bir işlem içinde oluşturur ve yürütür. |
Doğru veya Yanlış | Yanlış | Evet | İşlem üst bilgisi için bir SOAP hatası döndürülür. |
Yanlış | Doğru | Evet | Yöntem işlem olmadan yürütülür. |
Doğru | Doğru | Evet | Yöntem, akışı yapılan işlem altında yürütülür. |