How to deal with large objects?

2019-06-02 07:01发布

I have 5 types of objects: place info (14 properties),owner company info (5 properties), picture, ratings (stores multiple vote results), comments.

All those 5 objects will gather to make one object (Place) which will have all the properties and information about all the Place's info, pictures, comments, etc

What I'm trying to achieve is to have a page that displays the place object and all it's properties. another issue, if I want to display the Owner Companies' profiles I'll have object for each owner company (but I'll add a sixth property which is a list of all the places they own)

I've been practicing for a while, but I never got into implementing and performance experience, but I sensed that it was too much!

What do you think ?

2条回答
Anthone
2楼-- · 2019-06-02 07:23

You have to examine the use case scenarios for your solution. Do you need to always show all of the data, or are you starting off with displaying only a portion of it? Are users likely to expand any collapsed items as part of regular usage or is this information only used in less common usages?

Depending on your answers it may be best to fetch and populate the entire page with all of the data at once, or it may be the case that only some data is needed to render the initial screen and the rest can be fetched on-demand.

In most cases the best solution is likely to involve fetching only the required data and to update the page dynamically using ajax queries as needed.

As for optimizing data access, you need to strike a balance between the number of database requests and the complexity of each individual request. Because of network latency it is often important to fetch as much as possible using as few queries as possible, even if this means you'll sometimes be fetching data that you do not always need. But if you include too much data in a single query, then computing all the joins may also be costly. It is quite rare to see a solution in which it is better to first fetch all root objects and then for every element go fetch some additional objects associated with that element. As such, design your solution to fetch all data at once, but include only what you really need and try to keep the number of involved tables to a minimum.

查看更多
狗以群分
3楼-- · 2019-06-02 07:25

You have 3 issues to deal with really, and they are often split into DAL, BLL and UI

Your objects obviously belong in the BLL and if you're considering performance then you need to consider how your objects will be created and how they interface to the DAL. I have many objects with 50-200 properties so 14 properties is really no issue.

The UI side of it is seperate, and if you're considering the performance of displaying a lot of information onto a single page you'll consider tabbed content, grids etc.

Tackle it one thing at a time and see where your problems lie.

查看更多
登录 后发表回答