そのデータがテーブル内で一意である理由を特定する必要があります。顧客テーブルの場合は、おそらく13029の顧客IDです。ただし、顧客注文テーブルの場合は、CustomerIdとOrderDateの組み合わせである可能性があります(同じ日に2つの一意の注文を行った可能性があります)。あなたはあなたのテーブルのデザインに基づいてそれに対する答えを知るでしょう。
その知識があれば、ターゲットテーブルからキーをプルバックするクエリを作成する必要がSELECT CO.CustomerId, CO.OrderId FROM dbo.CustomerOrder CO
あります。プロセスが現在の年のデータのみを転送することがわかっている場合は、上記のクエリにフィルタを追加して、返される行数を制限します。この理由はメモリの節約です。SSISを高速に実行し、不要な列や行を戻さないようにする必要があります。
データフロー内で、そのクエリを使用してルックアップトランスフォーメーションを追加します。SSISバージョンとして2005、2008、または2012を指定せず、ルックアップトランスフォーメーションに関連する動作が異なります。一般的に言って、あなたがしようとしているのは、一致しない行を特定することです。定義上、不一致とは、それらがターゲットデータベースに存在しないことを意味するため、これらは新しい行です。2005は、すべての行が一致するか、エラーになると想定しています。[エラー出力の構成...]ボタンをクリックして、[行のリダイレクト]を選択する必要があります。2008+には、[一致するエントリがない行を処理する方法を指定する]の下にオプションがあり、[一致する出力がない行をリダイレクトする]必要があります。
次に、一致しない出力ブランチ(2008+)またはエラー出力ブランチ(2005)を取得し、それを宛先に追加します。
このアプローチでカバーされていないのは、ソースシステムが$ 56.82を報告し、ターゲットシステムが$ 22.38(更新)を持っている場合の検出と処理です。それを処理する必要がある場合は、変更検出システムを調べる必要があります。変更を検出して処理するためのオプションについては、 AndyLeonardのStairwaytoIntegrationServicesシリーズの記事を参照してください。