博客
关于我
强烈建议你试试无所不能的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

你可能感兴趣的文章
Python入门-函数
查看>>
[HDU5727]Necklace(二分图最大匹配,枚举)
查看>>
距离公式汇总以及Python实现
查看>>
设计模式之装饰者模式
查看>>
一道不知道哪里来的容斥题
查看>>
Blender Python UV 学习
查看>>
window添加右键菜单
查看>>
入手腾龙SP AF90mm MACRO
查看>>
python学习4 常用内置模块
查看>>
Window7上搭建symfony开发环境(PEAR)
查看>>
ResolveUrl的用法
查看>>
Linux内核态、用户态简介与IntelCPU特权级别--Ring0-3
查看>>
第23月第24天 git命令 .git-credentials git rm --cached git stash clear
查看>>
java SE :标准输入/输出
查看>>
一些方便系统诊断的bash函数
查看>>
【转载】基于vw等viewport视区相对单位的响应式排版和布局
查看>>
<转>关于MFC的多线程类 CSemaphore,CMutex,CCriticalSection,CEvent
查看>>
jquery中ajax返回值无法传递到上层函数
查看>>
css3之transform-origin
查看>>
[转]JavaScript快速检测浏览器对CSS3特性的支持
查看>>