zoukankan      html  css  js  c++  java
  • Effective C# Item41 : DataSet优于自定义结构

        大家认为DataSet不好的两个理由:1. 使用XML序列化机制的DataSet与非.NET代码之间的交互不是很好,使用DataSet的Web Services API很难与不支持.NET框架的系统交互;2. DataSet是一个非常通用的容器,程序员可能会牺牲某些.NET框架的类型安全而误用DataSet。

        DataSet设计的初衷:为关系型数据库的一个离线缓存,它可以存储很多歌DataTable,每个DataTable中又存储于数据库相匹配的行与列,DataSet及其成员都支持数据绑定,另外,DataSet还支持各个DataTable间的关系以及给DataSet中的数据添加约束。

        DataSet不是一个强类型容器,它是一个关于DataTable的字典集合,并且DataTable中的列也是一个字典结构,我们通常情况下,会使用以下的方式来访问DataSet中的数据。

    int val = ( int )MyDataSet.Tables[ "table1" ].Rows[ 0 ][ "total" ];
        以上有两个问题:1. DataSet中的数据都是System.Object类型,程序在使用时,还需要进行强制类型转换;2. 在访问DataSet中的数据时,还需要通过硬编码的方式来定位表名和列名。

        通常,我们希望以下面这种语句来访问DataSet中的数据。

    int val = MyDataSet.table1.Rows[ 0 ].total;

        如果想以上面这种方式来访问DataSet中的数据,我们可以有两种方式:1. 使用强类型的DataSet(个人不推荐,因为在系统开发阶段,很难保证数据结构的稳定性);2. 使用某种ORM框架,例如NHibernate。要尽量避免自己编写存储数据的结构。

  • 相关阅读:
    排序算法与数据结构复习总结
    Kafka知识总结及面试题
    深入理解Redis系列之事务
    深入理解Redis系列之持久化
    基于数据库、redis和zookeeper实现的分布式锁
    深入理解MySQL系列之优化
    Mysql-主从复制(Docker)
    Mysql-GTID主从复制
    Ansible基础
    Nginx + php-fpm源码编译
  • 原文地址:https://www.cnblogs.com/wing011203/p/1675125.html
Copyright © 2011-2022 走看看