使用属性和反射过渡从数据存取层到业务物件 - II
来源:互联网 发布:华泰证券交易软件ios 编辑:程序博客网 时间:2024/05/21 19:21
简介
前面的文章我介绍了使用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,用来在运行时间得到物件等等.
- 使用属性和反射过渡从数据存取层到业务物件 - II
- 使用属性和反射过渡从数据存取层到业务物件I
- 使用属性和反射过渡从数据存取层到业务物件1 (转)
- 使用属性和反射过渡从数据存取层到业务物件 - III
- 泛型+反射实现数据层+业务层
- 抽象工厂+反射+依赖注入 实现对数据访问层和业务逻辑层的优化
- 抽象工厂+反射+依赖注入 实现对数据访问层和业务逻辑层的优化
- 抽象工厂+反射+依赖注入 实现对数据访问层和业务逻辑层的优化
- 技巧和诀窍:使用PrincipalPermissionAttribute在业务和数据层中添加授权规则
- 技巧和诀窍:使用PrincipalPermissionAttribute在业务和数据层中添加授权规则
- Activiti 5.17 业务层和数据层的关系
- 【Java】业务层和数据访问层的区别
- iOS从手动管理内存过渡到使用ARC
- 从Windows过渡到Mac OS X上手使用经验谈
- 从数据源取回数据--Command 物件简介
- 软件的进化:从第一行代码到分离业务规则和数据显示
- 从Flex3过渡到Flex4
- 从svn过渡到git
- 利用临界区的多线程同步测试(转)
- [转载] 警惕—安逸的工作引发职业危机
- 不吃香海归如何就业 国内求职谨记五原则(转自sina)
- 大道如天,各行一边!
- 开源的DOS
- 使用属性和反射过渡从数据存取层到业务物件 - II
- 使用属性和反射过渡从数据存取层到业务物件 - III
- TeX中显示大小写罗马数字
- Javax.servlet API的特征
- php版的escape函数
- 向XPath中添加自定义函数
- 工作流的核心思想
- MS上有关XML的小工具
- vi的使用