我正在努力将良好的数据库设计概念与良好的面向对象设计联系起来.

传统上,如果我想在转发器中显示新闻故事列表,我会使用以下内容:

<script runat="server">

    void ShowNews()
    {
        rptNewsstories.DataSource = News.GetAllNews(); // Returns a DataTable
        rptNewsstories.DataBind();
    }

</script>

<asp:Repeater id="rptNewsstories" runat="server">
    <ItemTemplate>
        <div>
            <span class="Title"><%# Eval("Title")"%> (<%# Eval("Location")"%>)</span>
            <p>
                <%# Eval("Summary")"%>
            </p>
            <ul>
                <li>Added by: <%# Eval("AddedByFullName")%></li>
                <li>Added on: <%# Eval("AddedOn")%></li>
            </ul>
        </div>
    </ItemTemplate>
</asp:Repeater>

这里News.GetAllNews()返回一个DataTable,它只是存储过程返回的转储.写入存储过程是为了使用连接返回数据,因此它不止一个表的数据.

这样做的好处在于,在数据库中,存储过程可以查找谁从新闻表中存在的AddedByID添加新闻故事,并返回人员全名作为返回的AddedByFullName值.

但是,如果我尝试删除DataTable的使用而返回一个News对象的List,我会得到以下结果:

<script runat="server">

    void ShowNews()
    {
        rptNewsstories.DataSource = News.GetAllNews(); // Returns a List<News>
        rptNewsstories.DataBind();
    }

</script>

<asp:Repeater id="rptNewsstories" runat="server">
    <ItemTemplate>
        <div>
            <span class="Title"><%# Eval("Title")"%> (<%# Eval("Location")"%>)</span>
            <p>
                <%# Eval("Summary")"%>
            </p>
            <ul>
                <li>Added by: <!-- Here there is only a AddedByUserID,not an AddedByFullName value --></li>
                <li>Added on: <%# Eval("AddedOn")%></li>
            </ul>
        </div>
    </ItemTemplate>
</asp:Repeater>

但是现在我遇到的问题是,我想要显示的某些值(如AddedByFullName)在News对象中不存在,因为它们不是显式设置的,而是从查找ID中检索到的.宾语.

我想返回对象而不是DataTables,但我不知道弥合这个差距的最佳方法.

我是:
*在News类中为可以从数据库返回的与此数据相关的每个附加值创建其他属性?
*坚持使用DataTables来处理具有许多附加值的特定情况?

或者我完全走错了轨道!

解决方法

您的选择受到您愿意用作数据访问的基础技术的限制.目前,VS工具集和.Net框架支持多种替代方案:

>经典ADO.Net 2.0.在代码中设计Typed datasets和DataTable对象.
> LINQ to SQL.在LINQ O/R Design modeler中设计,在代码中使用IQueryable<T>和LINQ语法.
> Entity Framework.在Entity Data modeler中进行设计,在代码中使用实体.
>第三方ORM工具,如NHibernate.每个工具都有自己的特定设计器和代码对象类型.

除此之外,所有ADO.Net类型的数据集都允许您指定导航关系,就像您要求的那样,急切地或懒惰地加载.在你描述这些技术的自然兴趣的情况下,将在设计者中明确地模拟新闻文章和作者之间的关系,并让框架处理加载适当数据和适当类型的问题,最终意义连接问题由应用程序数据访问层(框架)隐式处理,而不是由显式创建的存储过程处理.

技术的选择将在您的代码中无处不在,从您获取数据的方式到显示方式以及更新方式,这些技术都不容易互换.就个人而言,我发现权力和复杂性的正确平衡是LINQ to sql.

c# – 从.net中的数据库返回数据:返回DataTable还是LIst?的更多相关文章

  1. swift3.0-第一篇tableView

    最近这个月估计要一直设计新的项目天天开会苦不堪言啊~新的项目要用swift来写,从零开始还是很有乐趣的,简单总结了下table的使用,一起学习下吧。直接上代码了感谢观看,学以致用更感谢哦~

  2. jQuery中Datatables增加跳转到指定页功能

    本文给大家分享jquery中datatable增加跳转到指定页面功能以及jquery datatable中加入双击跳转功能的实例代码,需要的朋友参考下

  3. 针对thinkPHP5框架存储过程bug重写的存储过程扩展类完整实例

    这篇文章主要介绍了针对thinkPHP5框架存储过程bug重写的存储过程扩展类,结合完整实例形式给出了修复thinkPHP5存储过程原有bug的扩展类定义与使用方法,需要的朋友可以参考下

  4. jQuery Datatable 多个查询条件自定义提交事件(推荐)

    这篇文章主要介绍了jQuery Datatable 多个查询条件自定义提交事件的相关资料,需要的朋友可以参考下

  5. Node.js中调用mysql存储过程示例

    这篇文章主要介绍了Node.js中调用mysql存储过程示例,本文在windows环境测试通过,本文一并给出了创建数据库、录入数据、创建存储过程、调用存储过程等例子,需要的朋友可以参考下

  6. Java下使用Oracle存储过程(详解)第1/3页

    其实,这篇短文,我早就应该写了。因为,java存储过程今后在各大数据库厂商中越来越流行,功能也越来越强大。这里以Oracle为例,介绍一下java存储过程的具体用法。

  7. PHP实现PDO操作mysql存储过程示例

    这篇文章主要介绍了PHP实现PDO操作mysql存储过程,结合具体实例形式分析了php使用pdo操作mysql存储过程实现用户注册功能相关技巧,需要的朋友可以参考下

  8. jQuery插件DataTable使用方法详解(.Net平台)

    这篇文章主要为大家详细介绍了jQuery插件DataTable使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  9. angularJs中datatable实现代码

    本篇文章主要介绍了angularJs中datatable实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. 使用jquery DataTable和ajax向页面显示数据列表的方法

    今天小编就为大家分享一篇使用jquery DataTable和ajax向页面显示数据列表的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

随机推荐

  1. c# – (wpf)Application.Current.Resources vs FindResource

    所以,我正在使用C#中的WPF创建一个GUI.它看起来像这样:它现在还没有完成.这两行是我尝试制作一种数据表,它们在XAML中是硬编码的.现在,我正在C#中实现添加新的水果按钮功能.我在XAML中有以下样式来控制行的背景图像应该是什么样子:因此,在代码中,我为每列col0,col1和col2创建一个图像,如果我使用以下代码,它添加了一个如下所示的新行:如你所见,它不太正确……为什么一个似乎忽略了一些属性而另一个没有?

  2. c# – 绑定DataGridTemplateColumn

    似乎我已经打了个墙,试图在DataGrid上使用DataTemplates.我想要做的是使用一个模板来显示每个单元格的两行文本.但是似乎无法以任何方式绑定列.以下代码希望显示我想做的事情.注意每个列的绑定:模板列没有这样的东西,因此,这个xaml不可能工作.我注定要将整个DataTemplate复制到每个列,只是对每个副本都有不同的约束?解决方法我不完全确定你想要做什么,但如果您需要获取整行的DataContext,可以使用RelativeSource绑定来移动视觉树.像这样:

  3. c# – 学习设计模式的资源

    最近我来到了这个设计模式的概念,并对此感到非常热情.你能建议一些帮助我深入设计模式的资源吗?

  4. c# – 是否有支持嵌入HTML页面的跨操作系统GUI框架?

    我想开发一个桌面应用程序来使用跨系统,是否有一个GUI框架,允许我为所有3个平台编写一次代码,并具有完全可脚本化的嵌入式Web组件?我需要它有一个API来在应用程序和网页之间进行交流.我知道C#,JavaScript和一些python.解决方法Qt有这样的事情QWebView.

  5. c# – 通过字符串在对象图中查找属性

    我试图使用任意字符串访问嵌套类结构的各个部分.给出以下(设计的)类:我想要从Person对象的一个实例的“PersonsAddress.HousePhone.Number”获取对象.目前我正在使用反思来做一些简单的递归查找,但是我希望有一些忍者有更好的想法.作为参考,这里是我开发的(crappy)方法:解决方法您可以简单地使用标准的.NETDataBinder.EvalMethod,像这样:

  6. c# – 文件下载后更新页面

    FamilyID=0a391abd-25c1-4fc0-919f-b21f31ab88b7&displaylang=en&pf=true它呈现该页面,然后使用以下元刷新标签来实际向用户提供要下载的文件:你可能需要在你的应用程序中做类似的事情.但是,如果您真的有兴趣在文件完全下载后执行某些操作,那么您的运气不佳,因为没有任何事件可以与浏览器进行通信.执行此操作的唯一方法是上传附件时使用的AJAXupload.

  7. c# – 如何在每个机器应用程序中实现单个实例?

    我必须限制我的.net4WPF应用程序,以便每台机器只能运行一次.请注意,我说每个机器,而不是每个会话.我使用一个简单的互斥体实现单实例应用程序,直到现在,但不幸的是,这样一个互斥是每个会话.有没有办法创建机器互连,还是有其他解决方案来实现每个机器应用程序的单个实例?

  8. c# – WCF和多个主机头

    我的雇主网站有多个主机名,都是同一个服务器,我们只是显示不同的皮肤来进行品牌宣传.不幸的是,在这种情况下,WCF似乎不能很好地工作.我试过overridingthedefaulthostwithacustomhostfactory.这不是一个可以接受的解决方案,因为它需要从所有主机工作,而不仅仅是1.我也看过thisblogpost,但是我无法让它工作,或者不是为了解决我的问题.我得到的错误是“这

  9. c# – ASP.NET MVC模型绑定与表单元素名称中的虚线

    我一直在搜索互联网,试图找到一种方式来容纳我的表单元素的破折号到ASP.NET的控制器在MVC2,3或甚至4中的默认模型绑定行为.作为一名前端开发人员,我更喜欢在我的CSS中使用camelCase或下划线进行破折号.在我的标记中,我想要做的是这样的:在控制器中,我会传入一个C#对象,看起来像这样:有没有办法通过一些正则表达式或其他行为来扩展Controller类来适应这种情况?我讨厌这样的事实,我必须这样做:甚至这个:思考?

  10. c# – 用户界面设计工具

    我正在寻找一个用户界面设计工具来显示文档中可能的GUI.我不能生成代码.我知道MicrosoftVisio提供了一个功能.但有什么办法吗?您使用哪种软件可视化GUI?

返回
顶部