上一主题下一主题
«12345»Pages: 1/46     Go
关键字
主题 : FluentData - 轻量级.NET ORM持久化技术解决方案
级别: VIP四级

UID: 230365
精华: 12
发帖: 314
威望: 3432 点
学点: 380 点
贡献: 2 点
好评: 1 点
学币: 0 个
注册时间: 2010-04-16
最后登录: 2014-09-25
楼主  发表于: 2014-06-06 10:13||

1 FluentData - 轻量级.NET ORM持久化技术解决方案

管理提醒: 本帖被 zylzyl 执行加亮操作(2014-06-06)
基于ASP.NET MVC 4 +Knockout.JS+Web API+FluentData+EasyUI 技术实现Web通用商业****发框架(学习版):点此了解详情
l_^>spF  
"%A[%7LY  
.NET Web****发零基础到商业项目实战北风特训营(赠送价值近百万商业源码):点此了解详情
wrGd40  
 Q+dBSKSK  
FluentData - 轻量级.NET ORM持久化技术解决方案 t6-c {ZX>A  
?_n.B=H`8  
目录: t$Irr*  
Mt@K01MI%  
一、什么是ORM? 0FTiTrTn  
二、使用ORM的优势 D8[& }D4  
三、使用ORM的缺点 Vy-S9=  
四、NET下的ORM框架有哪些? d5^ipu  
五、几种常用框架的比较 n!HFHy2  
六、什么是FluentData? WxO*{`T!  
七、快速上手如何使用FluentData? 9h*$P:S;1v  
八、****资源下载 mjs*Z{_F^  
r=@h}TKv{I  
* k =L  
TU[f"!z^  
内容: P?]q*KViM  
ZMx_J  
一、什么是ORM? ZTt% 7K"L  
ORM,即Object-Relational Mapping(对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,这样,我们在具体的操作业务对象的时候,就不需要再去和复杂的SQL语句打交道,只需简单的操作对象的属性和方法。 m^]/ /j  
/=7|FtB`  
二、使用ORM的优势 WNL3+  
优势一、 隐藏了数据访问细节,“封闭”的通用数据库交互,ORM的核心。他使得我们的通用数据库交互变得简单易行,并且完全不用考虑该死的SQL语句。快速****发,由此而来。 !lu$WJ{M  
*q8W;Wa L  
优势二、ORM使我****乖旃袒萁峁贡涞眉虻ヒ仔小 rt~X (S  
j&8 ~X2?*  
         在ORM年表的史前时代,我们需要将我们的对象模型转化为一条一条的SQL语句,通过直连或是DB helper在关系数据库构造我们的数据库体系。而现在,基本上所有的ORM框架都****了通过对象模型构造关系数据库结构的功能。这,相当不错。 \DGm[/P  
jh8%Xu]t  
三、使用ORM的缺点 {b c<0  
第一:无可避免的,自动化意味着映射和关联管理,代价是牺牲性能(早期,这是所有不喜欢ORM人的共同点)。现在的各种ORM框架都在尝试使用各种方法来减轻这块(LazyLoad,Cache),效果还是很显著的。 Y`( I};MO  
第二:面向对象的查询语言(X-QL)作为一种数据库与对象之间的过渡,虽然隐藏了数据层面的业务抽象,但并不能完全的屏蔽掉数据库层的设计,并且无疑将增加学习成本. Jw {:1  
第三:对于复杂查询,ORM仍然力不从心。虽然可以实现,但是不值的。视图可以解决大部分calculated column,case ,group,h****ing,order by, exists,但是查询条件(a and b and not c and (d or d))。。。。。。 <w2Nh eM 3  
R9=,T0Y p  
       世上没有驴是不吃草的(又想好又想巧,****个老驴不吃草),任何优势的背后都隐藏着缺点,这是不可避免的。问题在于,我们是否能容忍缺点 !7bC\ {  
dc lJ  
四、.NET下的ORM框架有哪些? ih~c(&n0  
现在市面上针对.NET ORM框架越来越多 7c;59$2(  
微软自家的LINQ to SQL, ADO.NET Entity Framework不多说。 mX|AptND  
*FG@Dts^&  
商业: );Gt!]p`;  
1bj75/i<6  
1.LightSpeed(免费版比较垃圾。表限制8个。另此厂商有NHibernate Designer工具) W%1fm/ G0  
w;#9 hW&  
http://www.mindscapehq.com/products/lightspeed cUy6/x9&  
3:=XU9p)x  
2. Entityspaces(支持Access数据库,比较看好)。 rxDule3m  
Hs -NP#I  
http://www.entityspaces.net/portal/Home.aspx =BGc@:2  
3.OpenAccess(有比较给力的免费版。) Tmw :w~  
&"^A  
http://www.telerik.com/products/orm.aspx <F=j6U7   
wbr"z7}  
4.eXpressPersistent Objects(XPO)(支持Access) qt;6CzL C  
/n"A%6S  
http://www.devexpress.com/products/NET/ORM/ _fa]2I  
5.DataObjects.Net(自称对LINQ支持比较给力。但支持数据库比较少。有老版本的****源版) Y%&6qt G  
=,0E3:X^  
http://dataobjects.net/ N!Y'W)i16  
*`l>1)B>  
6.LLBLGen Pro (虽然支持的数据库比较多。但LINQ to SQL 只能用于MS SQL SERVER) <!w-op2@ir  
9r8{9h:  
http://www.llblgen.com/defaultgeneric.aspx Tzk8y 7$[  
7.LinqConnect , Entity Developer 和 dotConnect Universal (产品比较乱。对LINQ支持比较给力。有自动生成代码和可视化的工具。) {yG)Ii  
F^ Q  
http://www.devart.com/dotconnect/ slPFDBx  
8.DataDirect Connect for ADO.NET(这个是ORM吗?应该和微软的产品合用) Dt +"E  
3]c<7vdl  
http://www.datadirect.com/products/net/index.html :*oI"U*f  
.upcUS8  
9.ALINQ(国人****发。前期反编译了微软的SQL to SQL。后来自己写了各数据库provider发展而成。有免费版。中小型项目都可以用。但国人****发产品似乎充满困境。作者也****发了NHIbernate的代码生成器) ! w/~dy  
I&(cdKY z  
http://www.alinq.org/ !-;Me&"I=`  
o#+!H!C.O  
****源 ,,G0}N@7s  
:))AZ7_  
1.NHibernate(大名鼎鼎,发展不错。有很多书可学。) [J*)r8ys  
\|T0@V  
http://nhforge.org/Default.aspx chiQ+  
UW>~C  
2.Castle ActiveRecord (建立在NHibernate之上,用.net attribute 映射。不过基本都用NHibernate了。Castle有好多项目可学习参考) cAiIbh>c  
:X$&g sT/,  
http://www.castleproject.org/castle/projects.html hyTi':  
MWB uMF  
3.SubSonic (性能是问题。更新缓慢) Q5jP`<zWU  
TY88PXW  
http://subsonicproject.com/ \ _i`=dx  
{Qhv HV  
4. Opf3(貌似不更新了,可以学习用) V K NCK  
-|3U0: 'm  
http://opf3.codeplex.com/ c`t1:%S  
*v 8 ]99N  
{?j|]j  
5.MyBatis.NET (也不更新了。) nxH$$}9  
http://code.google.com/p/mybatisnet/ c~tkY !c  
DvhK0L*Qr  
@E==~ b  
TIvLY5 HG  
6.BLToolkit(网站貌似被和 谐。这个看介绍挺不错。支持的数据库也不少。性能据说也行。但似乎国内没人用。) t>25IJG  
R UX  
http://bltoolkit.net/ *PMql$  
https://github.com/igor-tkachev/bltoolkit rSZWmns  
#Y{"`5>  
0<s)xaN>Y  
N..u<06j/  
7.MyGeneration(代码自动生成工具和ORM。有各种模板。停止更新了) da-3hM!u+  
j"NqNv  
http://www.mygenerationsoftware.com/portal/default.aspx L?Lp``%bI7  
'/"(`f,  
五、几种常用框架的比较 a1}W2;W0]g  
以上就是市面上比较常见的.net ORM框架。其实比较完美的ORM框架应该是满足: %r>vZ/>a  
B"EMir'  
1.对象与数据库的映射 SOUA,4  
2.对象缓存 PNKmI  
3.可视化设计和代码生成工具 tb=(L  
4.支持多数据库 -,i1T(p1  
5.动态查询 6 =kd4'yV  
6.延迟加载 M9N|Ql  
7.非侵入式持久化 /qp`xJ  
8.性能优良 :J<S-d=  
9.支持存储过程和事务 Z@h]dU5%a  
10.多面向对象框架支持 *|jqRfa"  
0qTa @y  
ORM框架确实很方便,但发现也有其不足之处,比如多表联合查询,对视图和存储过程的****不理想。整体性能低于面向SQL语句。 pG4Hy$e  
以上几种框架比较常用的应该是NHibernate,微软的EF及MyBatis.NET和FluentData。 7'o?'He-.2  
上述几个框架各有优缺点 oFsMQ Py  
如:NHibernate 师出名门,大名鼎鼎的Hibernate厂商出品的专门针对.NET的ORM框架,优点是:功能强大,资料齐全,缺点是配置复杂,学习成本高 HN3 yA1<[V  
微软的EF自然是在VS****发中首推的,优点是和VS IDE集成很好,缺点是性能较NHiberte低,据说6.0后,性能明显加强,甚至于超过NHibernate,但本人未测,另外,对其他数据库的支持需要安装第三方插件,还有个人感觉也过于宠大,使用起来,不够灵活。MyBatic.NET功能和易用性介于NHibernate与EF之间。 xA-G&oC]<T  
相比较而言,****吒****使用FluentData,一个轻量级****源的.NET ORM数据持久化框架 <h;P<4JX  
'6aH*B:}*;  
六、什么是FluentData? N@)g3mX>  
FluentData:一种使用Fluent API的新型轻量级ORM模型 Z>{8FzP.F  
FluentData 是微型 ORM(micro-ORM)家族的一名新成员,旨在比大型 ORM(full ORM)更加易用。FluentData 于本月推出,它使用 fluent API 并支持 SQL Server、SQL Azure、Oracle 和 MYSQL。 :l 7\7IT  
7.=u:PK7kM  
  FluentData 的设计者 Lars-Erik Kindblad 谈到: !",@,$  
d-  ]%  
当前市面上的 ORM 框架,如 Entity Framework 和 NHibernate,都过于复杂而且难于学习。此外,由于这些框架自身抽象的查询语言以及从数据库到 .NET 对象的映射太过麻烦,导致它们生成的 SQL 都很低效。 (V+(\<M  
bEy%S "\<  
FluentData 另辟蹊径,它是一个轻量级框架,拥有简单的 fluent API 并且很容易学会。 C f+O7Y`^  
mtF&Z\ag  
  与其他微型 ORM(如 Dapper 和 Massive)类似,FluentData 关注性能和易用性。它允许****发人员拥有对 SQL 较多的控制,而不是依赖 ORM 进行自动生成。它不仅可以使用 SQL 来执行查询、增添和更新操作,还可以支持使用存储过程和事务。根据文档描述,FluentData 可以在不改动已有结构的情况下,与任何业务对象一同工作。 0)84Z.k  
@ce4sSo  
  以下是 FluentData 的一些其他特性: Q;Oc# u  
).&$pXj  
· 多结果集(Multiple Result Set):在一次数据库操作下返回多个数据集; Ge @d"  
· ****发人员可使用强类型对象或动态对象; L72GF5+!!  
· 可为创建时需要特殊****的复杂对象自定义实体工厂(Custom Entity Factory); }%:?s6Ler  
· 具有添加其他数据库支持的能力。 k4`v(au^  
FluentData 需要 .NET 4.0,并支持 SQL Server、SQL Azure、SQL Server Compact 以及使用 .NET 驱动的 Oracle 和 MySQL。 想要了解进一步信息,如代码示例和免费下载,请访问CodePlex 站点上的 FluentData。(http://fluentdata.codeplex.com/ mq "p"iI  
8pk5[=3Z  
,= PDL  
:b ;5O3:B  
七、快速上手如何使用FluentData `|v#x@s  
A,iXiDb3pK  
下面我将一一举例向大家介绍FluentData在****发过程中的运用. G{s ,Y^  
一:下载该项目并且引用FluentData.dll,或者直接在解决方案中添加该****源项目.项目地址:http://fluentdata.codeplex.com/ >,9t<p=Q  
二.dll引用入到我们的数据业务层. z,NHH):~  
1.)创建并且初始化一个IDbContext. _\1(7?0D  
它是我们与数据库操作中的上下文,所有的有关数据操作都调用它下面的方法。初始化它的连接字符串web.config mki=.l$O  
复制代码
  1. public static IDbContext QueryDB()
  2. {
  3.    return new DbContext().ConnectionStringName("testDBContext", DbProviderTypes.SqlServer);
  4. }
N1SRnJu<f  
(+ >n/I6  
2.)config中的连接字符串实例 1ri#hm0x\  
复制代码
  1. <connectionStrings>
  2.     <add name="testDBContext" connectionString="server=192.168.1.100;uid=sa;pwd=sa!;database=testDB;" />
  3.   </connectionStrings>
\myc n/e  
那么下面就可以在我们的数据业务层中根据自己的需求随心所欲的写sql了。 %?cPqRHJ ~  
1.需要返回一个实体: im?nR+t+X  
复制代码
  1. Product product = QueryDB().Sql(@"select * from Product
  2.                 where ProductId = 1").QuerySingle<Product>();
5<S1,u5  
2.根据参数返回一个实体?别急,尝尝那飘渺的链式操作吧 ]:f1r8<3p  
复制代码
  1. Product product = QueryDB().Sql("select * from Product where id=@id")
  2.                   .Parameter("id", id)
  3.                  .QuerySingle<Product>();
PJ_|=bn  
3.返回一个泛型。 .p5*&i 7  
复制代码
  1. List<Product> product = QueryDB().Sql("select * from Product where id=@id")
  2.                   .Parameter("id", id)
  3.                  .Query<Product>();
(g;Ff`P Pc  
4.多表支持(这个楼主实际工作中倒是没有用到过) g>Z1ZK0;M  
复制代码
  1. using (var command = QueryDB().MultiResultSql())
  2. {
  3.     List<Category> categories = command.Sql(
  4.             @"select * from Category;
  5.             select * from Product;").Query<Category>();
  6.     List<Product> products = command.Query<Product>();
  7. }
?K]k(ZV_+Y  
  5.插入操作 PK~okz4b  
复制代码
  1. var productId = QueryDB().Insert("Product")
  2.                 .Column("Name", "The Warren Buffet Way")
  3.                 .Column("CategoryId", 1)
  4.                 .ExecuteReturnLastId();
{!="PnB  
6.当然我喜欢写我牛B的sql。 6z( _^CY  
复制代码
  1. var productId = QueryDB().Sql(@"insert into Product(Name, CategoryId)
  2.                     values('The Warren Buffet Way', 1);").ExecuteReturnLastId();
!l&lb]V cz  
7.修改操作. j9,X.?Xvx  
复制代码
  1. QueryDB().Update("Product")
  2.         .Column("Name", "The Warren Buffet Way")
  3.         .Column("CategoryId", 1)
  4.         .Where("ProductId", 1)
  5.         .Execute();
U]P;X~$!  
同上,也可以不用update()方法,而直接写sql. ~C[,P\,  
8.****操作 ' ZB%McS  
QueryDB().Delete("Product").Where("ProductId", 1).Execute(); Hnaq+ _]  
9.我想链式操作,我想写lambda表达式OK。 EuAa  
复制代码
  1. QueryDB().Delete<Product>("Product")                                                    
  2.      .Where(x=>x.id,id)
  3.      .Execute();
]F_ u  
10.事物的**** Wl,yznT  
复制代码
  1. using (var context = QueryDB().UseTransaction)
  2. {
  3.     context.Sql("update Product set Name = @0 where ProductId = @1")
  4.                 .Parameters("The Warren Buffet Way", 1)
  5.                 .Execute();
  6.     context.Sql("update Product set Name = @0 where ProductId = @1")
  7.                 .Parameters("Bill Gates Bio", 2)
  8.                 .Execute();
  9.     context.Commit();
  10. }
a( qw  
在事物的操作中记得context.Commit();方法的执行,楼主曾经在自己的一个项目中需要用到事物,却忘记了执行提交这个方法,最后在源码的汪 洋中探索许久 hIw*dob  
11.存储过程 II2oV}7?  
有关存储过程的使用,楼主在实际项目****发中,用上了存储过程。该存储过程的作用是分页,那么这里也贴出来分享一下 d,>l;l  
复制代码
  1. public static List<T> getPage<T>(string tableName,string tableFields, string sqlWhere,string order,int pageIndex, int pageSize, out int total)
  2. {
  3.             var store = QueryDB().StoredProcedure("PF_Sys_PageControl")
  4.                                       .ParameterOut("totalPage", DataTypes.Int16)
  5.                                       .Parameter("tableName", tableName)
  6.                                       .Parameter("tableFields", tableFields)
  7.                                       .Parameter("sqlWhere", sqlWhere)
  8.                                      .Parameter("orderFields", order)
  9.                                       .Parameter("pageSize", pageSize)
  10.                                       .Parameter("pageIndex", pageIndex);
  11.             var result=store.Query<T>()
:4A^~+J  
d EXw=u  
上面贴的都是一些方法内容,具体的可以用方法封装下,当然该ORM是基于Freamework4.0的,Idbcontext接口下的方法也有支持返回一个动态类型的,所以扩展性也不弱。具体的就在于灵活的运用。 XR+2|o  
至此;写到这里一定很激动了吧,大伙有时间有机会的话,也去尝试下吧。 J|>P,x#G  
,5/g Ng  
八、****资源下载 &A`QPk8n  
~p8!Kb6  
关于NHibernate及EF在北风网官网上能找到我的教程,但关于FluentData的这个ORM框架的视频市面上虽有,却少,而且不系统完整,兼与此, |GsLcUv6  
我自己计划出一些关于FluentData的教学视频,已经在进行中,照例给出思维导图及已完成的视频,需了解更多的可以给我留言,希望我的付出对您有所帮助。 yf$7<gwX  
  [attachment=7044] ;m\(fW*ii  
已经录制好的视频有如下十二讲,后面计划会结合具体的案例项目更深入的讲解 _7;#0B  
  [attachment=7045] ~vt8|OOo0  
本次先公****课程的前三讲及部分代码(说明:代码请用VS2012打****),供大家入门参考! -}>Q0d)  
OU[Sm7B  
链接: http://pan.baidu.com/s/1eQkV4VC 2 o.Mh/D0  
&2 g1Oy~  
密码:
本部分内容设定了隐藏,需要回复后才能看到
5-sxTp  
y<gmp  
6Y=$7%z  
基于ASP.NET MVC 4 +Knockout.JS+Web API+FluentData+EasyUI 技术实现Web通用商业****发框架(学习版):点此了解详情
%@IR7v~  
4u;W1=+Vn  
.NET Web****发零基础到商业项目实战北风特训营(赠送价值近百万商业源码):点此了解详情
级别: 终身会员

UID: 120836
精华: 0
发帖: 193
威望: 1696 点
学点: 126 点
贡献: 0 点
好评: 0 点
学币: 0 个
注册时间: 2009-02-15
最后登录: 2015-12-14
沙发(1楼)  发表于: 2014-06-09 01:31||

very good  
级别: 北风爱好者

UID: 468312
精华: 0
发帖: 1
威望: 22 点
学点: 17 点
贡献: 2 点
好评: 0 点
学币: 0 个
注册时间: 2014-06-10
最后登录: 2014-11-28
板凳(2楼)  发表于: 2014-06-10 16:53||

学习一下
级别: VIP一级

UID: 331285
精华: 0
发帖: 314
威望: 3529 点
学点: 255 点
贡献: 1 点
好评: 0 点
学币: 0 个
注册时间: 2011-11-27
最后登录: 2015-03-28
地板(3楼)  发表于: 2014-06-10 16:54||

不错啊
级别: VIP五级

UID: 270178
精华: 0
发帖: 19
威望: 426 点
学点: 459 点
贡献: 46 点
好评: 0 点
学币: 8 个
注册时间: 2010-11-11
最后登录: 2018-04-21
地下室(4楼)  发表于: 2014-06-10 22:18||

顶一个,期待风老师的这个课程!
级别: VIP五级

UID: 461512
精华: 0
发帖: 8
威望: 2 点
学点: 23 点
贡献: 0 点
好评: 0 点
学币: 0 个
注册时间: 2014-04-16
最后登录: 2014-11-03
下水道(5楼)  发表于: 2014-06-13 13:53||

研究一下
级别: VIP五级

UID: 209947
精华: 0
发帖: 60
威望: 492 点
学点: 46 点
贡献: 0 点
好评: 0 点
学币: 0 个
注册时间: 2009-12-29
最后登录: 2014-11-17
6楼  发表于: 2014-06-15 15:32||

快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快快
级别: 北风爱好者

UID: 468945
精华: 0
发帖: 2
威望: 2 点
学点: 4 点
贡献: 0 点
好评: 0 点
学币: 0 个
注册时间: 2014-06-15
最后登录: 2014-06-15
7楼  发表于: 2014-06-15 21:35||

看看先!!!
我的青春我做主
级别: 终身会员

UID: 162806
精华: 0
发帖: 231
威望: 2355 点
学点: 2 点
贡献: 0 点
好评: 0 点
学币: 0 个
注册时间: 2009-05-22
最后登录: 2016-01-03
8楼  发表于: 2014-06-17 05:16||

学习一下
级别: 北风爱好者

UID: 469157
精华: 0
发帖: 2
威望: 2 点
学点: 4 点
贡献: 0 点
好评: 0 点
学币: 0 个
注册时间: 2014-06-17
最后登录: 2014-06-19
9楼  发表于: 2014-06-17 13:08||

不错啊
上一主题下一主题
«12345»Pages: 1/46     Go