关于ASP.Net的导入导出(4)

Com.urp.command.FileFrameWork4

这周真是不顺利,股市又一次经历了80点的大洗礼,自己投资的几个股票也是个个遇难,损失不少,总觉得中国股市的管理层又一次动用了黑手,可我们这些散户又能怎么样呢。就跟工作一样,上面的leader整天在那混日子,做设计的人也是马马乎乎的,我们这些底下的又怎么能写出好代码呢。

这次主要是把ModelCollection给补充完整了。建了个包LocalModel在形式上努力和DataSet保持一直,有些相同的基本操作。如用Column来表示列信息,Model来表示行信息。通过行来访问数据等。类图如下:

关于ASP.Net的导入导出(4)

基本上是模仿着DataSet写的,ModelCollection继承了CollectionBase,但这里需要注意的是,list里保存的不是LocalModel.Model,而是需要导入到数据库中的实体类,这样子做因为从高层上来看ModelCollection就仅仅是一个Ilist,并且我们可以通过this来访问ModelCollection,直接取到里面的数据,而那些其他方法都是可以忽略不看的。ModelProxy维护Column类,相关字段,属性的创建,调用都是由它来管理。但对于外层来说,他是个代理,是不可见的。访问属性是的创建多用了惰性创建。ModelCollection通过ModelProxy可以访问属性信息,通过Model可以给属性付值和取值。

例如我们采用NorthwindCustomers表来建立实体类(以后所有的例子都将采用Northwind数据库)。

Customer

实体类的信息我们采用xml来配置它。配置文件如下:

根据modelname,利用反射动态创建Customer类。Property中的name是类的属性名, column是要导入的文件里的列名,通过columnname匹配起来。根据import,export来决定是否需要导入,导出。defaultValue用来作为空字段的默认值。对于某些属性我们还能通过formatter来规范它转换格式。

这样配置其实只能对单个的实体类导入导出,所以我们以后的property可以通过修改name,比如通过name = " Contact.ContactName" 来访问联系人的名字。这样子在某种程度上就支持多表的导入导出。关于这个等以后在实现吧。现在导入的代码已经基本上可以形成了,下次整理一下就,放出完整的导入。

你可能感兴趣的:(asp.net)