博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
自己的ORMapping
阅读量:5100 次
发布时间:2019-06-13

本文共 2465 字,大约阅读时间需要 8 分钟。

看着大家都说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,是否需要模糊查询等
另外我还对它进行了操作符重载,以方便以后的查询。
代码片断:

ExpandedBlockStart.gif
ContractedBlock.gif
/**/
/// <summary>
InBlock.gif        
/// 相似于
InBlock.gif        
/// </summary>
InBlock.gif        
/// <param name="sr"></param>
InBlock.gif        
/// <param name="obj"></param>
ExpandedBlockEnd.gif        
/// <returns></returns>
None.gif
        
public
 
static
 
string
 
operator
 
%
( DataField sr, 
object
 obj )
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif
{
InBlock.gif            sr
+=obj;
InBlock.gif            
if(sr.ToString().Trim()=="")
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
return "";
ExpandedSubBlockEnd.gif            }
InBlock.gif            
return sql.And+sr.Name+sql.Like+"'%'"+sr.ToDBString()+"'%'";
ExpandedBlockEnd.gif        }

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方面的东东。

转载于:https://www.cnblogs.com/martinxj/archive/2005/07/28/201665.html

你可能感兴趣的文章
【转】单调队列初步
查看>>
Grep与web漏洞挖掘<转>
查看>>
树链剖分【p3038】[USACO11DEC]牧草种植Grass Planting
查看>>
.Net中的AOP系列之《单元测试切面》
查看>>
SqlServer根据表中ID加序号
查看>>
python之路_kindEditor编辑器及beautifulsoup模块
查看>>
(zz)最大子序列和问题
查看>>
C# Windows Api的一些方法 封装 以及 常用参数
查看>>
Spark RDD概念学习系列之Pair RDD的分区控制
查看>>
Hadoop工作流--JobControl(五)
查看>>
golang range循环内部
查看>>
JavaScript Array对象
查看>>
CocoaPods升级安装三方库报错
查看>>
idea server
查看>>
Linux系统日志及screen工具
查看>>
2014-12-02-2107-Java-UML
查看>>
20130909
查看>>
SQL语言:DQL,DML,DDL,DCL
查看>>
PB与各种数据库连接
查看>>
1003 阶乘后面0的数量
查看>>