.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);

}

(未完待续)

时间: 2024-09-13 18:51:35

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

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

数据 1 考虑多语言的问题对于多语言,需要考虑两个方面,一个是界面,一个是数据库信息,对于界面的多语言问题比较简单,只要建立相应的资源文件就可以了,这里不再多说:比较复杂的是数据库信息的多语言化,这里说说Freight.net的解决方案. Freight.net将使用Storm.MultiLanguage构件来处理多语言. 该构件可对数据库中的字符串数据表及XML格式的字符串数据表进行操作.默认的数据库表名为DisplayString,默认的XML文件名为DisplayStringData.XM

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

数据 3 考虑以上两种情况的综合 当以上两种情况凑在一块的时候,情况还会复杂一些,因为在我们的这个解决方案中,多语言和信息的主体是采用的松耦合,如果不采用松耦合就不能保证其通用性和可扩展性,但是采用了松耦合在数据集中多表操作时又会产生麻烦. 因为松耦合,所以在数据集中自动级连更新的时候并不能够自动更新,修改还无所谓,我们只要保证和多语言表关联的那个Guid不变就可以了,但是删除呢?我们总不能把信息主体删除了却又把多语言数据留着吧,更麻烦的是因为数据已经删除,我们很难知道删除之前与多语言数据表关联

ADO.NET中的多数据表操作浅析—读取

ado|数据 ADO.NET中的多数据表操作浅析-读取 作者:郑佐??????? 2004-8-5 ???????? 在开发基于.NET平台的数据库应用程序时,我们一般都会用到DataSet,作为ADO.NET的核心类它为我们提供了强大的功能,而整个看上去就像是放在内存内的一个小型数据库,内部包括了DataTable.DataView.DataRow.DataColumn.Constraint以及DataRelation.当初看到它时真的是有点兴奋. ???????? 下面根据我的一些经验来举例

ADO.NET中的多数据表操作浅析—修改

ado|数据 ADO.NET中的多数据表操作浅析-修改 作者:郑佐??????? 2004-8-5 三.更新数据集 首先需要说明的是我这里去掉了Order Details表,对两个表的操作只是其中的几个字段.下面是窗体界面: 图3-1 单选框用来选择不同的更新方法. 在DataAccess类中增加两个类成员变量: ???? private SqlDataAdapter _customerDataAdapter; //客户数据适配器 ???? private SqlDataAdapter _ord

(C语言版)数据结构线性表从键盘输入元素实现相关功能,不报错,但执行意外终止

问题描述 (C语言版)数据结构线性表从键盘输入元素实现相关功能,不报错,但执行意外终止 #include #include #define MaxSize 50 typedef char ElemType; typedef struct{//struct结构体 ElemType data[MaxSize]; int length; }SqList; void InitList(SqList &L)//初始化线性表的方法,&是取地址符号,是定义指针符号,如int *b=&a:*a=4

c语言-使用C语言实现memcached内数据交互

问题描述 使用C语言实现memcached内数据交互 使用C语言实现一个客户端,将一个随机数发送到memcached中,然后在memcached中进行查找.请问各位大神该怎么实现?? 解决方案 http://www.open-open.com/lib/view/open1338688577562.html

Go语言实现顺序存储的线性表实例_Golang

本文实例讲述了Go语言实现顺序存储的线性表的方法.分享给大家供大家参考.具体如下: 代码如下: 复制代码 代码如下: ///////// // 顺序存储线性表 //////// package main import "fmt" const MAXSIZE = 20 //定义数组长度 //定义线性表结构 type List struct {     Element [MAXSIZE]int //存储线性表元素的数组     length  int          //线性表长度 }

oracle 中的集合(联合数组 内嵌表 可变数组)

1.定义一个集合,让它作为一个函数或过程的形式参数,这样就可以传递这个集合类型的参数.    看下面的例子:定义一个过程参数--内嵌表                                          create or replace package personnel   --定义一个包  as      type staff_list is table of emp.empno%type;  -- 定义了一个emp.empno 的内嵌表,表的类型为emp_empno.  

关于django执行python manage.py syncdb命令却缺少自己所需要建的models.py内的表

问题描述 关于django执行python manage.py syncdb命令却缺少自己所需要建的models.py内的表 在django项目中的settings.py文件中的_app代码,数据库没问题,可以连接上,但是:python manage.py syncdb命令却无法生成自己models.py内所定义的实体类表. INSTALLED_APPS = ( 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.cont