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#法式設計有所贊助。