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

** 简介 ** ** **

前面的文章我介绍了使用 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, 用来在运行时间得到物件等等 .

Published At
Categories with Web编程
Tagged with
comments powered by Disqus