本文主要解决ORM开发过程中Model类在ORM层产生的信息,在开始这篇文章之前,你有必要了解这个轻量级ORM设置的类相关信息类以及属性相关信息类,如果你还不了解,请阅读一文轻量级ORM开发系列:Attribute准备一文。
在ORM中,每个Model类都有相关的属性以及信息(如TableAttribute),每个属性又对应着与之相关的信息(如ColumnAttribute,IgnoreAttribute等等),这篇文章主要描述一下我的属性信息是怎么解决的。
首先,我申明了一个EntityPropertyInfo类,这个类来存储与属性相关的信息。代码如下:
/// 说明:若是一个被忽略的属性,则只有相关的Property,Type信息,此时IsIgnore为true
/// </summary>
public class EntityPropertyInfo
{
/// <summary>
/// 对他所属于的EntityInfo的引用
/// </summary>
public EntityInfo EntityInfo { get ; set ; }
public String ColumnName { get ; set ; }
public Type Type { get ; set ; }
public PropertyInfo Property { get ; set ; }
public Boolean IsAutoIncrement { get ; set ; }
public Boolean IsIgnore { get ; set ; }
public ColumnAttribute ColumnAttribute { get ; set ; }
public static EntityPropertyInfo Get(PropertyInfo property, EntityInfo paraEntityInfo)
{
EntityPropertyInfo epi = new EntityPropertyInfo();
epi.Property = property;
epi.Type = property.PropertyType;
epi.EntityInfo = paraEntityInfo;
epi.IsIgnore = property.IsDefined( typeof (IgnoreAttribute), false );
if ( ! epi.IsIgnore) //
{
epi.ColumnAttribute = FoxReflection.GetAttribute(property, typeof (ColumnAttribute)) as ColumnAttribute;
// 列名的处理
epi.ColumnName = epi.ColumnAttribute == null ? property.Name : epi.ColumnAttribute.Column;
if (epi.ColumnAttribute == null )
{
epi.ColumnAttribute = new ColumnAttribute();
}
if (epi.ColumnName == null )
{
epi.ColumnName = property.Name; // 即使该属性有ColumnAttribute,但也不一定设定了列名
epi.ColumnAttribute.Column = property.Name; // 同步到ColumnAttribute,防止以后引用导致出错
}
if (property.PropertyType is IList)
{
// epi.HasOne2ManyRelation = true;
}
}
return epi;
}
}
这个类的Get方法还没有写完,如果你看到了这里,想进一步完善他的话可以与我取得联系获得源代码,我现在已经没有精力回头去研究这些东西了,这些博文也只是记录一下我在这段时期研究过哪些东西而已。如果你是为了学习的目的的话,我觉得还是会蛮有收获的,至少我觉得是这样。
EntityPropertyInfo类就是对一个属性所有的信息做一个集合。以方便后面的处理,这里我们同样对我们的Model进行一个这样的封装,建立一个新的类,EntityInfo类来集合所有的 Model在ORM中需要用到的信息。
public class EntityInfo
{
public TableAttribute Table{ get ; set ;}
/// <summary>
/// 标识是否已经对此类进行了CREAT_SQL语句生成
/// </summary>
public IList < PropertyInfo > PropertyList = new List < PropertyInfo > ();
public IList < EntityPropertyInfo > EntityPropertiesList = new List < EntityPropertyInfo > ();
public string TypeFullName { get ; set ; }
public string TableName { get ; set ; }
public string DataBaseName { get ; set ; }
/// <summary>
///
/// </summary>
public EntityPropertyInfo PrimaryKey { get ; set ; }
/// <summary>
/// 获取需要ORM操作的属性的个数
/// </summary>
/// <returns></returns>
public int GetUsedCount()
{
int count = 0 ;
foreach (EntityPropertyInfo epi in EntityPropertiesList)
{
if ( ! epi.IsIgnore)
{
count ++ ;
}
}
return count;
}
}
这里实现了一个IList<EntityPropertyInfo>的集合,这样一个类的所有属性就可以顺序的索引到。这位后面数据的赋值以及初始化等等操作都打下了基础。
public string TypeFullName { get; set; } //类型全名
public string TableName { get; set; } //映射的数据库表名
public string DataBaseName { get; set; } //数据库名,这意味着我们的程序可以跨数据库操作表。
有了这两个类,这个轻量级ORM信息处理的即使就打好了,当然,在后面我们会看到怎么让Model类以及其属性变成相应的EntityInfo类以及IList<EntityPropertyInfo>集合,在ORM里面我们不可能所有的信息都通过反射临时来获取,反射可不是省油的灯,所以我们在看轻量级ORM的缓存设计的时候也会基于这里讲到的两个存储信息的类。这些提到的部分将会在后面一一补充。