5

RavenDBは初めてです。マルチマップインデックス機能を使用しようとしていますが、それが私の問題に対する最善のアプローチであるかどうかはわかりません。つまり、ユニット、車、人の3つのドキュメントがあります。

車のドキュメントは次のようになります。

{
 Id: "cars/123",
 PersonId: "people/1235",
 UnitId: "units/4321",
 Make: "Toyota",
 Model: "Prius"
}

Peopleドキュメントは次のようになります。

{
   Id: "people/1235",
   FirstName: "test",
   LastName: "test"
}

そしてユニットドキュメント:

{
   Id: "units/4321",
   Address: "blah blah"
}

これは省略された例です。私の実際のアプリにははるかに多くのフィールドがあるため、データの非正規化が私の最後の手段になります。

この3つのドキュメントすべてを1つのドキュメントに結合するインデックスを作成してインデックスを作成する必要があります。このようなもの:

{
   CarId: "cars/123",
   PersonId: "people/1235",
   UnitId: "units/4321",
   Make: "Toyota",
   Model: "Prius"
   FirstName: "test",
   LastName: "test"
   Address: "blah blah"
}

// same unit different person owns a different car

{
   CarId: "cars/122",
   PersonId: "people/1236",
   UnitId: "units/4321",
   Make: "Toyota",
   Model: "4runner"
   FirstName: "test",
   LastName: "test"
   Address: "blah blah"
}

リレーショナルデータベースでは、IDによるPeopleテーブルとUnitテーブルへの2つの結合を使用するだけで、carテーブルは集約エンティティになります。

これが私が持っているインデックス定義です:

 public class MyMultiIndex : AbstractMultiMapIndexCreationTask<JoinedDocument>
 {
    public MyMultiIndex()
    {
        // creating maps
        AddMap<Car>(cars => cars.Select(e => new { e.CarId, e.Make, e.Model, PersonId = e.PersonId, UnitId = e.UnitId, FirstName = (null)string, LastName = (null)string, Address = (nul)string }));
        AddMap<People>(people => people.Select(e => new { CarId = (string)null, Make = (string)null, Model = (string)null, PersonId = e.Id, UnitId = (null)string, FirstName = e.FirstName, LastName = e.LastName, Address = (nul)string }));
        AddMap<Unit>(people => people.Select(e => new { CarId = (string)null, Make = (string)null, Model = (string)null, PersonId = (null)string, UnitId = e.null, FirstName = (nul)string , LastName = (nul)string , Address = e.Address }));

        Reduce = results => from result in results
                            group result by result.CarId
                            into g
                            select new JoinedDocument
                            {
                                CarId = g.Key,
                                PersonId = g.First(e => e.CarId == g.Key).PersonId,
                                UnitId = g.First(e => e.CarId == g.Key).UnitId,
                                Model = g.First(e => e.CarId == g.Key).Model,
                                Make = g.First(e => e.CarId == g.Key).Make,

                                **// this never works. It is like result set does not contain anything with this personId. It looks like AddMap for people document did not work.**

                                FirstName = results.First(e => e.PersonId == g.First(ie => ie.CarId == g.Key).PersonId).FirstName,

                                **// this never works. It is like result set does not contain anything with this personId. It looks like AddMap for people document did not work.**

                                LastName = results.First(e => e.PersonId == g.First(ie => ie.CarId == g.Key).PersonId).LastName,

                                **// this never works. It is like result set does not contain anything with this personId. It looks like AddMap for unit document did not work.**

                                UnitAddress = results.First(e => e.UnitId == g.First(ie => ie.CarId == g.Key).UnitId).LastName,
                           };
        Index(map => map.Model, FieldIndexing.Analyzed);
        Index(map => map.Make, FieldIndexing.Analyzed);
        Index(map => map.LastName, FieldIndexing.Analyzed);
        Index(map => map.FirstName, FieldIndexing.Analyzed);
        Index(map => map.Make, FieldIndexing.Analyzed);
        Index(map => map.UnitAddress, FieldIndexing.Analyzed);
    }
 }

RavenDbがこのインデックスを実行すると、提供したReduce関数を実行しようとしたときにエラーが表示されます。人の名と姓が存在するレコードを照合しようとするとエラーがスローされます。ユニットでも同じことが起こります。

4

2 に答える 2

1

ドキュメントデータベースを、関係のあるオブジェクトモデルに適合させようとしているようです。このブログはあなたを助けるかもしれません:

RavenDBでドメインモデルを純粋に保つ

これはRavenDBの推奨される使用法ではないことを覚えておいてください。ただし、必要な場合もあり、これはそれを処理するための良い方法です。

于 2012-04-19T01:42:00.837 に答える
1

所有者のいない車を持てますか?または居住者のいない住所?どちらの場合も間違っている場合は、人の中に埋め込まれるように車とユニットをモデル化します。したがって、その人はあなたの集合的なルートになり、車やユニットに到達するには、人を通り抜ける必要があります。

于 2012-04-28T07:38:20.297 に答える