私は単純なIFindSaga
を実装しましたが、SQL Persistence Saga Finding Logicの特定のソフトウェアドキュメントで提供されているのと同じ手順を参照して従いました。 「SynchronizedStorageSession
にはGetSagaData
の定義が含まれておらず、SynchronizedStorageSession
型の最初の引数を受け入れる拡張メソッドGetSagaData
はありません(使用するディレクティブまたはアセンブリ参照がありません)。これを解決するために私を助けてください。単純なIFindSagaを実装する
は、これは私がIFindSaga
public class TrackerFind : IFindSagas<SagaData>.Using<ITrackerData>
{
public Task<SagaData> FindBy(ITrackerData message, SynchronizedStorageSession session, ReadOnlyContextBag context)
{
return session.GetSagaData<SagaData>(
context: context,
whereClause: "JSON_VALUE(Data,'$.PaymentTransactionId') = @propertyValue",
appendParameters: (builder, append) =>
{
var parameter = builder();
parameter.ParameterName = "propertyValue";
parameter.Value = message.TrackerID;
append(parameter);
});
}
}
あなたはこれを以下の通りに実施している私のコードですか? https://github.com/Particular/docs.particular.net/blob/master/samples/saga/sql-sagafinder/SqlPersistence_2/EndpointSqlServer/OrderSagaFinder.cs –
https://docs.particular.net/samples/saga/ sql-sagafinder/ すべての必要な参照はありますか? –
NServiceBusドキュメントのコードスニペットには、このようなことを助けるための "Copy usings"オプションがあります。また、カスタムサーガファインダーはNServiceBusの非常に独創的な機能ですので、私たちは(特定のソフトウェアのために働いています)、カスタムサガファインダーを使用するための具体的なユースケースを聞くことに非常に興味があります。 PaymentTransactionIdを通常の相関プロパティーとして使用します。 –