首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MVC ViewBag:在视图中使用ViewBag访问数据库比直接访问更快

MVC ViewBag:在视图中使用ViewBag访问数据库比直接访问更快
EN

Stack Overflow用户
提问于 2011-08-09 13:46:48
回答 1查看 1.1K关注 0票数 0

我想知道什么更快。是将从DB查询的信息存储到ViewBag中,然后访问并显示在视图中,还是应该直接在View中进行查询。控制器是MVC中的中间层,因此在我看来,访问控制器中的DB应该更快是合乎逻辑的。

示例:

1)控制器中的--我访问DB并将信息放入ViewBag中,以便在视图中显示它。

主计长:

代码语言:javascript
复制
EVENT e = db.EVENT.Find(id);
ViewBag.event = e;

if (e.poster_id != null)
{
    poster = e.DATA.path;
}
ViewBag.dict_poster = poster;

意见:

代码语言:javascript
复制
<p>POSTER: @ViewBag.dict_poster;</p>

2)控制器中的--我只将来自DB的一般数据放入ViewBag中,并在视图中访问它。

主计长:

代码语言:javascript
复制
EVENT e = db.EVENT.Find(id);
ViewBag.event = e;

意见:

代码语言:javascript
复制
<p>
    @if(ViewBag.event.poster_id != null)
    {
        @ViewBag.event.DATA.path;
    }
</p>

  • 有什么更好更适合使用的?什么更快?
  • ,如果我有一个非常分支的DB,并且必须将所有内容存储到"ViewBag.e“中,那么将单个值存储到ViewBags中比在视图中访问它们更好、更快,还是直接访问视图更快?
  • 怎么办?(将DB信息存储到列表中,放在ViewBag中,而不是在视图中访问)

我很感谢你的回答和补充解释.

EN

回答 1

Stack Overflow用户

发布于 2011-08-09 13:56:28

您不应该直接从视图访问数据层,这应该在控制器中完成。另外,考虑将强类型视图模型传递给视图,而不是使用ViewBag。

在MVC中使用视图模型的原因请参见http://theminimalistdeveloper.com/2010/08/21/why-when-and-how-to-use-typed-views-and-viewmodel-pattern-in-asp-net-mvc/

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6997156

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档