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

ASP.NET
ASP.NET创建XML Web服务全接触(3)
ASP.NET创建XML Web服务全接触(4)
ASP.NET创建XML Web服务全接触(5)
ASP.NET创建XML Web服务全接触(6)
ASP.NET创建XML Web服务全接触(7)
ASP.NET创建XML Web服务全接触(8)
ASP.NET创建XML Web服务全接触(9)
ASP.NET创建XML Web服务全接触(10)
ASP.NET创建XML Web服务全接触(11)
ASP.NET创建XML Web服务全接触(12)
ASP.NET创建XML Web服务全接触(13)
ASP.NET创建XML Web服务全接触(14)
ASP.NET创建XML Web服务全接触(15)
asp.net高级教程(一)-asp.net or asp+
asp.net高级教程(二)-转换编程思维
asp.net高级教程(三)-对象
asp.net高级教程(四)-实战篇
asp.net高级教程(五)-实战篇(中)
ASP.NET 打造互联网未来空间站(1)
ASP.NET 打造互联网未来空间站(2)

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


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