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

ASP.NET
Script:WINDOWS Script 枚举运行中进程
使用Flex结合Webservice完成域名查询
VSTS Team System 总算装好了。
用于部署数据库的 数据库初始化工具 xzSQLDeploy Tools V1.0 (for SQLServer) f...
一个将阿拉伯数字转换成中文大写的最简单算法
SCRIPT:使用Windows Script 关闭和打开指定程序
Script:使用WINDOWS脚本访问WEB SERVICES
asp.net连接Access数据库
VB中IIS Application发布可能出现的问题
VB打包后的安装问题
Nhibernate的数据分页技术(续)
使用API函数复制文件,可显示进度。
VB打包技巧
VB.NET实现DirectSound9 (9) 实现示波器
VB.NET 实现DirectSound9 (10) 均衡器
[水晶报表部署系列之一]轻松搞定水晶报表9.2打包
DataGrid 中双向排序的一种办法
利用System.EventHandler来实现两个窗体间的事件调用
多线程应用程序中调用窗体的一点心得
Smart Client之旅一:用B/S方式运行Exe应用程序

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


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