在 ASP.NET 中拉多个记录集时的 DataReader 或 DataSet

DataReader or DataSet when pulling multiple recordsets in ASP.NET(在 ASP.NET 中拉多个记录集时的 DataReader 或 DataSet)
本文介绍了在 ASP.NET 中拉多个记录集时的 DataReader 或 DataSet的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个 ASP.NET 页面,其中包含一堆需要填充的控件(例如下拉列表).

I've got an ASP.NET page that has a bunch of controls that need to be populated (e.g. dropdown lists).

我想单次访问数据库并带回多个记录集,而不是为每个控件进行往返.

I'd like to make a single trip to the db and bring back multiple recordsets instead of making a round-trip for each control.

我可以带回一个 DataSet 中的多个表,或者我可以带回一个 DataReader 并使用.NextResult"将每个结果集放入一个自定义业务类中.

I could bring back multiple tables in a DataSet, or I could bring back a DataReader and use '.NextResult' to put each result set into a custom business class.

我是否会看到使用 DataReader 方法获得足够大的性能优势,还是应该只使用 DataSet 方法?

Will I likely see a big enough performance advantage using the DataReader approach, or should I just use the DataSet approach?

任何您通常如何处理此问题的示例将不胜感激.

Any examples of how you usually handle this would be appreciated.

推荐答案

  1. 如果您有超过 1000 条记录要从您的数据库中获取.
  2. 如果你不是很感兴趣自定义存储和自定义分页"对于 GridView"
  3. 如果您的服务器有内存压力.
  4. 如果连接没有问题每次该页面时您的数据库调用.
  1. If you have more than 1000 record to bring from your DataBase.
  2. If you are not very interested with custom storing and custom paging "For GridView"
  3. If your server have a memory stress.
  4. If there is no problem to connect to your DataBase every time that page called.

那我觉得用DataReader比较好.

其他

  1. 如果您从数据库中获取的记录少于 1000 个.
  2. 如果您对存储和分页对于GridView"
  3. 如果您的服务器没有内存压力.
  4. 如果您想连接到您的数据库只需一次并获取缓存的好处.
  1. If you have less than 1000 record to bring from your DataBase.
  2. If you are interested with storing and paging "For GridView"
  3. If your server haven't a memory stress.
  4. If you want to connect to your DataBase just one time and get the benefits of Caching.

那我觉得用DataSet比较好.

我认为我是对的.

这篇关于在 ASP.NET 中拉多个记录集时的 DataReader 或 DataSet的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
how do i pass parameters to aspnet reportviewer(如何将参数传递给aspnet report查看器)
Bind multiple parameters from route and body to a model in ASP.NET Core(在ASP.NET Core中将路由和主体中的多个参数绑定到一个模型)
Custom model binding in AspNet Core WebApi?(AspNet Core WebApi中的自定义模型绑定?)
How to minify in .net core mvc view?(如何在.Net核心MVC视图中缩小?)