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

ASP.NET
在ASP.NET中如何用C#.NET实现基于表单的验证
ADO.NET Entity Framework 试水:并发
.Net的精髓:XML和SOAP
多语言开发的个人体验
ASP.NET Routing对请求的处理方式
探索.Net中的委托
使用 ASP.NET 加密口令
[ASP.NET] Session 详解
ASP+ 与 Java
从ASP迁移至ASP+
从ASP迁移至ASP+ ----------进入DataSet
从ASP迁移至ASP+ --将HTML表格转换为ASP+数据列表
从ASP迁移至ASP+ --处理会话变量(Session Variables)
ASP+ 与 Java(一)
ASP+ 与 Java(二)
asp+的论坛列表程序---代码部分
asp+的论坛列表程序---页面部分
什么是受管(managed)?
用c#写的asp+域名查询程序
ASP+联结数据库

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 87 ::
收藏到网摘: 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,用来在运行时间得到物件等等.