.net多语言和数据集内多数据表的处理(2)

2                  考虑一个数据集中有多个数据表的问题

好处是什么?

很重要的一点,可以很方便的导航取得相关的信息,如Province.GetCityRows ()可以获得这个省下面的所有城市Province.CountryRow则可以得到这个省所在的国家,是不是比以前通过外键再到数据库去查方便的多呢?

伴随着这种导航而来的是方便的级连更新,比如删除了父记录就会自动地所有关联的子记录删除,这些都是自动进行的,你不需要多写一行代码。

其实,这些都是比较小的功能,更强大的功能在于方便的统计和聚合,考虑这么一个需求:对于商品类别表ProductType,我需要计算每一类商品的价格总和并保存到ProductType标的Total列中,我们以前会怎么做呢?现在我们可以这么写ds.ProjectType.TotalColumn. Expression = “Sum(Child.Price)”;这样是不是很方便呢?再比如,对于学校的班级表Class,希望统计每一个班所有学生成绩(fraction)的标准差并保存在Class表的StDev列中,那么我们可以这么写ds.Class.StDevColumn.Expression = “StDev(Child.fraction”就可以了。

数据集架构:采用这种编写方式开发的数据集架构大概是这个样子

          可以看到这个数据集里包含了几乎所有的地址数据,通过表间的关联我们便可以非常方便的在数据集中导航。

          如何与数据库同步?

          很不幸的,数据库的发展还没有赶上步伐,以至于我们在与数据库同步的时候不得不考虑很多,我希望,在SQL SERVER的下一个版本中将不再需要我们这么麻烦。

          从数据库获取数据时,我们需要实例化多个数据适配器,每个数据适配器针对一张数据表,然后把它们承载的数据分别填充到数据集中相应的数据表中;

          而把数据更新会数据库的时候,我们也需要实例化多个数据适配器,然后依次更新数据库的表,在这个步骤中,你要仔细考虑它们之间的顺序,新增记录的时候,要先主表后子表,删除的时候要先子表后主表。

          如下所示:

       public SystemData GetSystemInfo (SqlConnection sqlcon)

         {

              SystemData ds = new SystemData();

 

              SqlDataAdapter DAUsers = new SqlDataAdapter(SystemSQL.strGetUsers,sqlcon);

              DAUsers.Fill(ds.Users);

 

              SqlDataAdapter DARole = new SqlDataAdapter(SystemSQL.strGetRole,sqlcon);

              DARole.Fill(ds.Role);

 

              SqlDataAdapter DARUserRole = new SqlDataAdapter(SystemSQL.strGetRUserRole,sqlcon);

              DARUserRole.Fill(ds.RUserRole);

 

              SqlDataAdapter daModule = new SqlDataAdapter(SystemSQL.strGetModule,sqlcon);

              daModule.Fill(ds.Module);

 

              SqlDataAdapter daModuleFunction = new SqlDataAdapter(SystemSQL.strGetModuleFunction,sqlcon);

              daModuleFunction.Fill(ds.ModuleFunction);

 

              SqlDataAdapter daRoleFunction = new SqlDataAdapter(SystemSQL.strGetRoleFunction,sqlcon);

              daRoleFunction.Fill(ds.RoleFunction);

 

              SqlDataAdapter daUserFunction = new SqlDataAdapter(SystemSQL.strGetUserFunction,sqlcon);

              daUserFunction.Fill(ds.UserFunction);

 

              SqlDataAdapter daUserCustomParam = new SqlDataAdapter(SystemSQL.strGetUserCustomParam,sqlcon);

              daUserCustomParam.Fill(ds.UserCustomParam);

 

              return ds;

         }

     public void InsUpdUsers(SystemData ds)

         {

              DataTableExtend[] dts = new DataTableExtend[4];

              dts[0] = new DataTableExtend(ds.Users, "Users");

              dts[1] = new DataTableExtend(ds.RUserRole,"RUserRole");

              dts[2] = new DataTableExtend(ds.UserCustomParam,"UserCustomParam");

              dts[3] = new DataTableExtend(ds.UserFunction,"UserFunction");

             

              SQLModify.ModifyDataBase(dts,dbName);

         }

 

         public void UpdDelUsers(SystemData ds)

         {

              DataTableExtend[] dts = new DataTableExtend[4];

              dts[0] = new DataTableExtend(ds.RUserRole,"RUserRole");

              dts[1] = new DataTableExtend(ds.UserCustomParam,"UserCustomParam");

              dts[2] = new DataTableExtend(ds.UserFunction,"UserFunction");

              dts[3] = new DataTableExtend(ds.Users, "Users");

              SQLModify.ModifyDataBase(dts,dbName);

         }

 

 

(未完待续)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值