当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 使用属性和反射过渡从数据存取层到业务物件 - II

ASP.NET
DVNEWS 3.2 1013版免虚拟目录的安装方法,只要三个步骤
DataRow的序列化问题
VB.net基础:使用UDP发送和接收消息
采用HttpModules来重写URLs(实践篇)
要用到事务了
DataGrid中单元格的比较
动态引用WebService,建立WebService虚拟机
[初学VB.NET]数据绑定
使用ASP调用WebService时不能以Name为数据库中的字段
在VB.NET里操作文本文件
web下打印的办法
怎样把SQL_SERVER数据库里的(类型是image)图片显示在aspx页面里的image控件里
C#中字符串的加密
中小企业信息应用的利器:DAP-Dynamic Applications Platform
数据库系统概论学习笔记
体会到译者的艰辛,也发现了他们犯的错误
IISManager V1.1 是一个在线管理IIS,维护站点组件,安全稳定,最重要的是完全免费。
VS FlexGridPro 8.0如何在window98运行---有没有升级版本,急请高手指点
给立方体添加纹理
Wrox的C#高级编程第三版第一部分第一章(1~9页)

ASP.NET 中的 使用属性和反射过渡从数据存取层到业务物件 - II


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 109 ::
收藏到网摘: n/a

简介前面的文章我介绍了使用attributes来描述业务物件.这篇文章我将会展示如何从类中提取描述信息.为了解释它是如何工作的,我将通过前面在类中使用的attributes写个应用来创建sql脚本用来生成表.工具这是一个控制台应用.工具将会装载装配件,列举出类中标有DataTable的attibute生成sql脚本用来创建表.开始装载部分代码:public static void Main(string[] args){ if (args.Length != 1) { Console.WriteLine("Usage: scriptgen [assembly path]"); return; } Assembly assembly = null; try { assembly = Assembly.LoadFrom(args[0]); } catch (Exception e) { Console.WriteLine("Failed to load assembly [" + args[0] + "]"); Console.WriteLine(e.Message); } }以上的代码试图通过参数路径来装载装配件.现在我们必须列举出所有的含有datatable attribute的装配件.为了完成这个工作,请看如下代码:public void ParseAssembly(Assembly assembly){ Type[] types = assembly.GetTypes(); foreach(Type type in types) { if (type.IsClass) { DataTableAttribute[] dataTable = (DataTableAttribute[]) type.GetCustomAttributes(typeof(DataTableAttribute), true); if (dataTable.Length > 0) { Console.WriteLine("Found class '{0}'", type.ToString()); } } }}以下是列举属性的代码.void ParseClass(Type type, DataTableAttribute dataTable){ PropertyInfo[] properties = type.GetProperties(); // gets the key field foreach (PropertyInfo property in properties) { KeyFieldAttribute[] key = (KeyFieldAttribute[]) property.GetCustomAttributes(typeof(KeyFieldAttribute), true); if (key.Length > 0) { Console.WriteLine("Key = " + property.Name + " type is " + property.PropertyType); break; } } // gets the other fields foreach (PropertyInfo property in properties) { BaseFieldAttribute[] field = (BaseFieldAttribute[]) property.GetCustomAttributes(typeof(BaseFieldAttribute), true); if (field.Length > 0) { if (!(field[0] is KeyFieldAttribute)) { Console.WriteLine("Property " + property.Name + " [" + property.PropertyType + "] " + + "maps to column [ + field[0].ColumnName + "]"); } } }}现在我们不得不创建sql脚本.我们的工具仅能满足2个需求: key是int,identify 属性类型只有这些是允许的:string,int,decimal,和datetime.源文件将会创建以下的装配件: DAL.dll: 包含 attributes Customer.dll: 包含业务物件 scriptGen.exe: 用来生成sql脚本的工具. 下一步接下来的文章我将创建整个DAL,用来在运行时间得到物件等等.