中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > .NET > 临时文章
使用属性和反射过渡从数据存取层到业务物件 - II
作者:未知 时间:2004-11-17 12:12 出处:Blog 责编:chinaitpower
              摘要:暂无

简介

前面的文章我介绍了使用attributes来描述业务物件.这篇文章我将会展示如何从类中提取描述信息.为了解释它是如何工作的,我将通过前面在类中使用的attributes写个应用来创建sql脚本用来生成表.

工具

这是一个控制台应用.工具将会装载装配件,列举出类中标有DataTableattibute生成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个需求: keyint,identify 属性类型只有这些是允许的:string,int,decimal,datetime.

文件将会创建以下的装配件:

  • DAL.dll: 包含 attributes
  • Customer.dll: 包含业务物件
  • scriptGen.exe: 用来生成sql脚本的工具.

下一步

接下来的文章我将创建整个DAL,用来在运行时间得到物件等等.

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有