首页 > 编程 > .NET > 正文

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

2024-07-10 13:03:34
字体:
来源:转载
供稿:网友
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);

}





(未完待续)
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表