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

ASP.NET
在C#中导入WebBrowser控件,生成具有强名称的程序集
Asp.Net中的脚本回调和Server.Transfer页面传值
暂时性的解决datagrid控件数据绑定时候xxx字段不属于xxx表的错误
http://www.donews.net/yangwl/archive/2004/10/17/136872.aspx
Some tips for using visual studio .net
Grasshopper简介(节选)
ORACLE 常用的SQL语法和数据对象
[DNN学习所得]让IE也能实现解压缩功能(提供演示源码下载)
学习笔记之Microsoft Windows服务
关于XML:以对象模型为中心
P&P Enterprise Library Extensions
简易的字符替换,可以用于用户自我介绍输入框,简单新闻回复& etc.
缩略图多路径多格式保存
"关机/休眠/重启/注销"的类
[DNN功能]自己动手做语言包
处理WinForm多线程程序时的陷阱
获得光标在多行textbox中的行与列的函数
ADO.NET 和 ADO 的比较
vb.net类的封装,继承,多态,抽象之一
Display XML in AxSHDocVw.AxWebBrowser

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


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