自己的ORMapping

看着大家都说ORMapping框架,我也来掺和掺和,平时自己闲着没事做一个ORMapping的架构,我给它起名为SharpRush,就是开发C#程序特别快的意思。本人又喜欢打Starcraft,平常在浩方上看人家都是Rush、Rush的,所以就起名叫SharpRush了。
设计思想
1.和微软的System.Data相对应
                    我的                                           对应微软的                 
主要包含:DataCollection(集合类)              DataTable       
                    DataEntity(实体类)                     DataRow
                    DataField(实体类属性)              DataColumn
1.1 DataCollection(抽象类)继承System.Collection.CollectionBase,所有集合类的基类,可以转变为DataTable,DataTable也可以转变为DataCollection。DataCollection可以有子DataCollection
1.2 DataEntity(抽象类),包含实体对数据的增删改查,所有实体类的基类,可以转变为DataRow
1.3 DataField(结构类型),我把数据库的自动和此结构类型相映射。现在大部分的ORMapping框架都是写在XML中,或者是利用Attribute。我是利用结构,我想这一点,速度上面应该比它们快。
里面包含了数据库字段名,字段类型(System.Data.DbType),长度,是否必输,中文显示名称,是否允许编辑,是否可以Insert,是否Update,是否需要模糊查询等
另外我还对它进行了操作符重载,以方便以后的查询。
代码片断:

/// <summary>
        
/// 相似于
        
/// </summary>
        
/// <param name="sr"></param>
        
/// <param name="obj"></param>
        
/// <returns></returns>

        public static string operator %( DataField sr, object obj )
        
{
            sr
+=obj;
            
if(sr.ToString().Trim()=="")
            
{
                
return "";
            }

            
return sql.And+sr.Name+sql.Like+"'%'"+sr.ToDBString()+"'%'";
        }

1.4 有了这些信息,在实体类的保存之前,实体类根据DataField映射信息,自动判断输入是否符合要求。
那么在界面上的大部分验证信息

2.反映关系
2.1.主明细表 实体类中可以包含集合类,当加载实体类时,可以指定是否需要深度加载。需要深度加载时加载实体类中的集合类。
public virtual bool Load()
public virtual bool LoadWithMemberwiseCollection()
保存时也同样:
public virtual bool Save()
public virtual bool SaveWithMemberwiseCollection()

2.2 关系视图
自己定义了一个RelationCollection和RelationBuilder
例如:EmployeeEntity emp=new EmployeeEntity();
DeptEntity detp=new DeptEntity();
RelationBuilder rb=new RelationBuilder(emp,emp.DeptId);
RelationCollection relcol=rb.InnerJoin(dept,dept.DeptId); //可以InnerJoin,LeftOuterJoin,RightOuterJoin
relcol.Load();
访问relcol,可以用relcol[0][emp.EmpName],relcol[0][dept.DeptName]
另外可以根据recol这个集合再InnerJoin
例如:
CompanyEntity com=new CompanyEntity();
recol.InnerJoin(dept.CompanyId,com,com.CompanyId);//进行再度Join

3.查询语法
加载集合数据
EmployeeCollection col=new EmployeeCollection();
EmployeeEntity entity=new EmployeeEntity();
string str="";
str+=entity.EmpName % "Elevenwolf"
col.Load(str); //代码行数是不是很少啊?

保存实体类
EmployeeEntity entity=new EmployeeEntity();
entity.EmpName="Elevenwolf";
entity.Save(); //Save方法有抽象类DataEntity实现。

4.和.net控件绑定
dataGrid1.DataSource=col; //集合类可以直接绑定到控件上
或者:
dataGrid1.DataSource=col.ToDataTable();
这样的话,当dataGrid1改变时,绑定到它上面的DataTable也会跟着变。也就是说集合类也会跟着变。这就充分的利用到了.net控件的优势。

5.和UIMapping的关联
为了更好的提高开发效率,自己做了一套UIMapping,就是说界面上的控件和实体类中的属性相绑定。
那么的话,我们在开发时就不需要写给页面控件赋值的代码了。

6.多数据库支持

7.另外,实现了一些AOP,IoC,Config,Log方面的东东。

posted @ 2005-07-28 09:24  Martin XJ  阅读(2983)  评论(4编辑  收藏  举报