此系列文章记录我开发ORM的过程。
开篇:Attribute准备
我们需要利用Attribute来完成某些信息的配置,在nhibernate中我们使用的是XML文件来配置主键,字段映射,实体之间的关系,级联操作等等关系。这也带来了许多的问题,大部分的使用nhibernate开发的人员都会抱怨XML文件的管理,以及编写问题。笔者实践的这个ORM为了更好的提高用户体验,决定舍弃XML配置关系信息的方式,所有的相关信息都使用Attribute来实现。例如:
public class student{
string name;
string child_name;
}
一个学生类,包含两个信息。姓名以及小时候的名字,如果我们的业务逻辑需要,把所有学生小时候的名字同意显示为 “小+name" 那么我们就根本不需要开辟child_name属性到数据库,自然也就不需要保存了。这是使用Attribute来实现这一功能我们可以这样写:
[Ignore]
string child_name;
当然首先我们需要实现这些Attribute。
既然上面已经提到了这个 [Ignore] 那么我们就来先实现它吧。
[Serializable, AttributeUsage(AttributeTargets.Property)]
public class IgnoreAttribute : Attribute
{
}
看出个究竟来了没有?为什么类里面是空的?这样做的意义是什么?
这里的 IgnoreAttribute仅仅只是起到一个标识作用,这就相当于一个bool类型的属性,它只有两种可能,不是true就是false,这也是同样的道理,用定义了 [Ignore]与没有定义 [Ignore]来模拟true和false。[Serializable]标识该类能够被序列化,方便以文件的方式持久保存。AttributeUsage(AttributeTargets.Property)表示[Ignore]这个Attribute只能用于属性,不能用于方法或类。强制定义它的使用范围。
本文既然是 Attribute准备 ,那么我们就要一次性实现所有的Attribute。
ColumnAttribute[AttributeUsage(AttributeTargets.Property)]
public sealed class ColumnAttribute : Attribute
{
private string _column;
private DataType dataType;
private int length=255;
private bool canNull=true;
private object defaultValue;
private bool autoIncrement = false;
private bool isUnique=false;
public ColumnAttribute()
{
}
public ColumnAttribute(string paraColumn,DataType dataType)
{
this._column = paraColumn;
this.dataType = dataType;
}
public ColumnAttribute(string paraColumn,DataType dataType,int length,bool canNull,object defaultValue,bool autoIncrement,bool isUnique)
{
this._column = paraColumn;
this.dataType = dataType;
this.length = length;
this.canNull = canNull;
this.defaultValue = defaultValue;
this.autoIncrement = autoIncrement;
this.isUnique = isUnique;
}
/// <summary>
/// 表字段的数据类型
/// </summary>
public DataType DataType
{
get { return dataType; }
set { dataType = value; }
}
/// <summary>
/// 数据库中的列
/// </summary>
public string Column
{
get { return _column; }
set { _column = value; }
}
/// <summary>
/// 表字段的长度
/// </summary>
public int Length
{
get { return length; }
set { length = value; }
}
/// <summary>
/// 表字段是否可以为空
/// </summary>
public bool CanNull
{
get { return canNull; }
set { canNull = value; }
}
/// <summary>
/// 表字段的默认值
/// </summary>
public object DefaultValue
{
get { return defaultValue; }
set { defaultValue = value; }
}
/// <summary>
/// 表字段是否为自动增长列
/// </summary>
public bool AutoIncrement
{
get { return autoIncrement; }
set { autoIncrement = value; }
}
/// <summary>
/// 确定某个字段是否唯一
/// </summary>
public bool IsUnique
{
get { return isUnique; }
set { isUnique = value; }
}
}RelationAttribute[AttributeUsage(AttributeTargets.Property)]
public class RelationAttribute:Attribute
{
public RelationAttribute()
{
}
public RelationAttribute(Cascade paracascade,Relation pararelation)
{
_cascade = paracascade;
_relation = pararelation;
}
private Cascade _cascade = Cascade.None;
private Relation _relation = Relation.None;
/// <summary>
/// 表之间的关系
/// </summary>
public Relation Relation
{
get { return _relation; }
set { _relation = value; }
}
/// <summary>
/// 级联操作
/// </summary>
public Cascade Cascade
{
get { return _cascade; }
set { _cascade = value; }
}
}TableAttribute[AttributeUsage( AttributeTargets.Class )]
public sealed class TableAttribute:Attribute
{
private string _PrimaryKey;
private string name;
private string version = "V1.0";
/// <summary>
/// 无参数构造方法
/// </summary>
public TableAttribute()
{
}
public TableAttribute(string name)
{
this._PrimaryKey ="ID";
this.name = name;
}
public TableAttribute(string name,string version, string DataBaseName)
{
this._PrimaryKey = "ID";
this.name = name;
this.version = version;
}
/// <summary>
/// 数据表名
/// </summary>
public string Name
{
get { return name; }
set { name = value; }
}
public string DataBaseName { get; set; }
/// <summary>
/// 表实体版本号
/// 默认为 "V1.0"
/// </summary>
public string Version
{
get { return version; }
set { version = value; }
}
/// <summary>
/// 表字段是否为主键
/// </summary>
public string PrimaryKey
{
get { return _PrimaryKey; }
set { _PrimaryKey = value; }
}
}
以及上面已经提供的IgnoreAttribute一起。这四个Attribute将完成所有的配置信息关系的表示。
这里有必要进行一些简单的介绍
ColumnAttribute : 定义每一列的相关信息(包括表字段的数据类型,数据库中的列名,表字段的长度,表字段是否可以为空,表字段的默认值等等信息,具体有哪些请参见这个类的注释。
RelationAttribute: 定义每一列与其他Model的关系,包括many2many,many2one等关系,再后面的文章中将会一一讲述。
TableAttribute : 定义每个类所对应的表名,主键等信息。
好了,今天就到这里,请听下回分解。