1

次のlinqクエリを作成しましたが、期待される結果が得られません。たとえば、期待される結果は、lstとリストの間のすべての一致するレコードと、リストからのすべての一致しないレコードです。

次の結果が欲しい

a,b,c,d,e,f

public class Com : IEqualityComparer<DuplicateData>
    {
        public bool Equals(DuplicateData x, DuplicateData y)
        {
            return x.address.Equals(y.address);
        }

        public int GetHashCode(DuplicateData obj)
        {
            return obj.address.GetHashCode();

        }
    }

static void Run ()
{
    List<string> lst = new List<string>();
    lst.Add("a");
    lst.Add("b");
    lst.Add("c");
    lst.Add("p");

    List<DuplicateData> list = new List<DuplicateData>()
    {
        new DuplicateData{address="a"},
        new DuplicateData{address="a"},
        new DuplicateData{address="a"},
        new DuplicateData{address="b"},
        new DuplicateData{address="b"},
        new DuplicateData{address="c"},
        new DuplicateData{address="d"},
        new DuplicateData{address="e"},
        new DuplicateData{address="f"},
    };

    var dup = list.Distinct(new Com());
    var RightJoin = from x in dup
                    join y in lst
                    on x.address equals y
                    into right
                    from z in right
                    select new
                    {
                        UniqueAddress = z,

                    };

}
4

2 に答える 2

2

次のようにしてみてください。

var RightJoin = from x in dup
                join y in lst
                on x.address equals y
                into right
                from z in right.DefaultIfEmpty(x.address)
                select new
                {
                    UniqueAddress = z,
                };

結果は (a,b,c,d,e,f)

作業サンプル: http://ideone.com/MOIhZH


説明

linq で左/右の結合を作成するには、DefaultIfEmptyメソッドを使用する必要があります。これにより、一致しない場合 (結合された結果が空になる場合) (デフォルト) の結果が得られます。ただし、文字列のデフォルト値は でnullあるため、結果セットで表示するには、「左側」コレクションからデフォルト値を指定する必要があります。


代替アプローチ

これはおそらくより便利なアプローチです。zから選択してデフォルト値を提供する代わりにx.address、結合の左側から選択します。

var RightJoin = from x in dup
                join y in lst
                on x.address equals y
                into right
                from z in right.DefaultIfEmpty()
                select new
                {
                    UniqueAddress = x.address,
                };
于 2013-07-09T10:29:16.170 に答える
0

これはうまくいくはずです:

var res = from x in list
          join y in lst on x.address equals y into right 
          from xy in right.DefaultIfEmpty()
          select new { UniqueAddress = xy };

結果:

{ UniqueAddress = a },
{ UniqueAddress = a },
{ UniqueAddress = a },
{ UniqueAddress = b },
{ UniqueAddress = b },
{ UniqueAddress = c },
{ UniqueAddress = null },
{ UniqueAddress = null },
{ UniqueAddress = null }
于 2013-07-09T10:07:18.297 に答える