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

你可能感兴趣的文章
1.linux ping:unknown host www.***.***
查看>>
无向图求桥 UVA 796
查看>>
Nginx+Keepalived 实现双击热备及负载均衡
查看>>
五分钟搭建WordPress博客(二)
查看>>
Vue_(组件通讯)子组件向父组件传值
查看>>
jvm参数
查看>>
Something-Summary
查看>>
Spring学习笔记
查看>>
6个有用的MySQL语句
查看>>
linux c/c++ IP字符串转换成可比较大小的数字
查看>>
我对前端MVC的理解
查看>>
[网络流24题] 最长k可重区间集问题 (费用流)
查看>>
剑指offer系列32-----对称二叉树的判断
查看>>
Silverlight实用窍门系列:19.Silverlight调用webservice上传多个文件【附带源码实例】...
查看>>
2016.3.31考试心得
查看>>
20. 多态
查看>>
pip国内源
查看>>
docker 从本地拷贝文件
查看>>
HTTP状态码
查看>>
转载一个关于javascript弹出窗口的详解
查看>>