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