程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> C#依據反射和特征完成ORM映照實例剖析

C#依據反射和特征完成ORM映照實例剖析

編輯:C#入門知識

C#依據反射和特征完成ORM映照實例剖析。本站提示廣大學習愛好者:(C#依據反射和特征完成ORM映照實例剖析)文章只能為提供參考,不一定能成為您想要的結果。以下是C#依據反射和特征完成ORM映照實例剖析正文


本文實例講述了C#依據反射和特征完成ORM 映照的辦法。分享給年夜家供年夜家參考。詳細以下:

(一)關於反射

甚麼是反射?

反射就是在運轉時,靜態獲得對象信息的辦法。好比:運轉時取得對象有哪些屬性,辦法,拜托等。

反射的感化?

可以或許完成運轉時,靜態挪用對象的辦法,和靜態設置、獲得屬性值等。

反射的示例:

using System;
using System.Reflection;
namespace CS_Test
{
  public class MyStudent
  {
    private string sName;
    public string SName
    {
      get { return sName; }
      set { sName = value; }
    }
    private int sAge;
    public int SAge
    {
      get { return sAge; }
      set { sAge = value; }
    }
  }
  class Test_Attribute
  {
    [STAThread]
    static void Main(string[] args)
    {
      MyStudent stu1 = new MyStudent();
      stu1.SName = "劉德華";
      stu1.SAge = 40;
      // 取得一切屬性
      PropertyInfo[] pros = stu1.GetType().GetProperties();
      // 顯示一切屬性值
      foreach (PropertyInfo pro in pros)
       Console.WriteLine(pro.Name+":"+pro.GetValue(stu1,null));
      //更改stu1對象的SAge值
      stu1.GetType().GetProperty("SAge").SetValue(stu1, 30, null);
      // 顯示一切屬性值
      foreach (PropertyInfo pro in pros)
       Console.WriteLine(pro.Name+":"+pro.GetValue(stu1, null));
    }
  }
}

(二)關於特征

甚麼是 Attribute?

它是對運轉時的對象或對象的屬性、辦法、拜托等停止描寫的類。
Attribute 的感化?
用於在運轉時,描寫你的代碼或許影響你的法式的行動。

留意:

既然Attribute 是類,那末它的界說與界說類一樣。
獨一分歧的就是,自界說Attribute 類必需繼續於System.Attribute 空間。
特征的示例:

//描寫數據庫字段的 Attribute
public class DataFieldAttribute : Attribute
{
    public DataFieldAttribute(string fieldName,string fieldType)
    {
      this._fieldName = fieldName;
      this._fieldType = fieldType;
    }
    // 數據庫字段名
    private string _fieldName;
    public string FieldName
    {
      get { return _fieldName; }
      set { _fieldName = value; }
    }
    // 數據庫字段類型
    private string _fieldType;
    public string FieldType
    {
      get { return _fieldType; }
      set { _fieldType = value; }
    }
}

經由過程自界說Attribute,我們界說了類屬性和數據庫字段的逐個對應關系,因而對MyStudent 類的Name、Age 屬性都加上Attribute 的描寫,指定他們對應的數據庫字段名和類型。
代碼更改以下:

public class MyStudent
{
    private string _name;
    //應用“特征”描寫對應的數據庫字段名、類型
    [DataFieldAttribute("SName", "varchar")]
    public string Name
    {
      get { return _name; }
      set { _name = value; }
    }
    private int _age;
    [DataFieldAttribute("SAge", "int")]
    public int Age
    {
      get { return _age; }
      set { _age = value; }
    }
}

(三)ORM 映照規矩的界說

給實體類增長DataFieldAttribute 的描寫,其實就是增長了O(對象)/ R(關系數據庫)的映照規矩。
上面我們就經由過程反射的辦法完成:在運轉時靜態獲得O/R  Mapping 的映照規矩:

static void Main(string[] args)
{
  MyStudent stu1 = new MyStudent();
  stu1.Name = "劉德華";
  stu1.Age = 40;
  //經由過程反射的辦法來靜態獲得此映照規矩
  PropertyInfo[] infos = stu1.GetType().GetProperties();
  object[] objs_fieldAttr = null;
  foreach (PropertyInfo info in infos)
  {
    // GetCustomAttributes: 
    // 前往實體對象中每一個屬性對應的“特征”信息(數據庫字段名、類型)
    objs_fieldAttr = info.GetCustomAttributes(
               typeof(DataFieldAttribute), false);
    if (objs_fieldAttr != null)
    {
      Console.Write("實體類的屬性名:" + info.Name);
      Console.Write(" -> 數據庫字段名:");
      Console.WriteLine(((DataFieldAttribute)objs_fieldAttr[0]).FieldName);
    }
  }
}

顯示成果:

實體類的屬性名:Name -> 數據庫字段名:SName
實體類的屬性名:Age -> 數據庫字段名:SAge
 
接上去的任務就是:如何依據這類辦法靜態地從對象中獲得映照規矩,然後靜態結構Insert、Update、Delete 等 SQL 語句。這就是完成本身的ORM 的道理。
 
這裡的代碼僅僅是舉例,而要真正完成一個ORM,我們還須要斟酌的許多,好比:

1、實體類對應於哪張數據庫表?
2、數據庫表中的 PK  和 FK(假如有的話)怎樣表現?

完全代碼以下:

using System;
using System.Reflection;
namespace CS_Test
{
  public class MyStudent
  {
    private string _name;
    //應用“特征”描寫對應的數據庫字段名、類型
    [DataFieldAttribute("SName", "varchar")]
    public string Name
    {
      get { return _name; }
      set { _name = value; }
    }
    private int _age;
    [DataFieldAttribute("SAge", "int")]
    public int Age
    {
      get { return _age; }
      set { _age = value; }
    }
  }
  //描寫數據庫字段的 Attribute
  public class DataFieldAttribute : Attribute
  {
    public DataFieldAttribute(string fieldName,string fieldType)
    {
      this._fieldName = fieldName;
      this._fieldType = fieldType;
    }
    // 數據庫字段名
    private string _fieldName;
    public string FieldName
    {
      get { return _fieldName; }
      set { _fieldName = value; }
    }
    // 數據庫字段類型
    private string _fieldType;
    public string FieldType
    {
      get { return _fieldType; }
      set { _fieldType = value; }
    }
  }
  class Test_Attribute
  {
    [STAThread]
    static void Main(string[] args)
    {
      MyStudent stu1 = new MyStudent();
      stu1.Name = "劉德華";
      stu1.Age = 40;
      // 取得一切屬性
      PropertyInfo[] pros = stu1.GetType().GetProperties();
      // 顯示一切屬性值
      foreach (PropertyInfo pro in pros)
       Console.WriteLine(pro.Name+":"+pro.GetValue(stu1,null));
      //更改stu1對象的SAge值
      stu1.GetType().GetProperty("Age").SetValue(stu1, 30, null);
      // 顯示一切屬性值
      foreach (PropertyInfo pro in pros)
       Console.WriteLine(pro.Name+":"+pro.GetValue(stu1, null));

      //經由過程反射的辦法來靜態獲得此映照規矩
      PropertyInfo[] infos = stu1.GetType().GetProperties();
      object[] objs_fieldAttr = null;
      foreach (PropertyInfo info in infos)
      {
        // GetCustomAttributes: 
        // 前往實體中每一個屬性對應的“特征”信息(數據庫字段名、類型)
        objs_fieldAttr = info.GetCustomAttributes(
                typeof(DataFieldAttribute), false);
        if (objs_fieldAttr != null)
        {
          Console.Write("實體類的屬性名:" + info.Name);
          Console.Write(" -> 數據庫字段名:");
          Console.WriteLine(((DataFieldAttribute)objs_fieldAttr[0]).FieldName);
        }
      }
    }
  }
}

願望本文所述對年夜家的C#法式設計有所贊助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved