Lazy loading in MongoDB with NoRM

前端 未结 2 776
猫巷女王i
猫巷女王i 2021-01-20 09:47

I have a model similar to this: (simplified)

Question:

public class Question
{
    public string QuestionID { get; set; }

    publi         


        
相关标签:
2条回答
  • 2021-01-20 09:48

    OK, the concept of "Lazy Loading" is mostly foreign to a database like MongoDB. Take a look at your schema: Question has a List of Answers.

    In an RDBMS the "lazy" part allows you to load "the list" separately from the original. There are actually two queries happening, you're just trying to delay the second query.

    In MongoDB there's only one query happening. The Answers are embedded inside of the question, so your request for Questions automatically includes the list of Answers.

    Please take a look at the NORM samples for a better example of this: http://normproject.org/samples

    The basic point is that the structure you provided is no longer multiple tables. It's just one collection with embedded documents. So the concept of "Lazy Loading" is really unnecessary because you can't "Lazy Load" one query.

    0 讨论(0)
  • 2021-01-20 10:00

    I appreciate that this is an old thread, but other people may still be finding it (as I did). Lazy loading is both possible in MongoDB and supported by the C# driver.

    Check out the following classes: LazyBsonDocument and LazyBsonArray

    From the C# Driver tutorial documentation : "The lazy classes are special in that they defer the deserialization of BSON until it is needed. This is useful for when you only need a field or two out of a complex document because it will not incur the cost of deserializing the entire document or array, but just the pieces that are necessary. This deserialization occurs a level at a time."

    At the time of writing the tutorial document can be found here: http://docs.mongodb.org/ecosystem/tutorial/use-csharp-driver/

    The example given is very similar to the question in that it involved a nested collection, so it looks like the list of answers could indeed be lazy loaded if that was desirable.

    Hope this helps someone,

    Nick

    0 讨论(0)
提交回复
热议问题