码迷,mamicode.com
首页 > 其他好文 > 详细

快速上手如何使用FluentData

时间:2015-09-05 17:36:44      阅读:449      评论:0      收藏:0      [点我收藏+]

标签:

http://blog.itpub.net/29511780/viewspace-1194048/

目录: 
 
一、什么是ORM? 
二、使用ORM的优势 
三、使用ORM的缺点 
四、NET下的ORM框架有哪些? 
五、几种常用框架的比较 
六、什么是FluentData? 
七、快速上手如何使用FluentData? 
八、提供资源下载 


七、快速上手如何使用FluentData

本文摘自:http://bbs.ibeifeng.com/read-htm-tid-66379.html 

下面我将一一举例向大家介绍FluentData在开发过程中的运用. 
一:下载该项目并且引用FluentData.dll,或者直接在解决方案中添加该开源项目.项目地址:http://fluentdata.codeplex.com/ 
二.dll引用入到我们的数据业务层. 
1.)创建并且初始化一个IDbContext. 
它是我们与数据库操作中的上下文,所有的有关数据操作都调用它下面的方法。初始化它的连接字符串web.config 

点击(此处)折叠或打开

  1. public static IDbContext QueryDB()
  2. {
  3.    return new DbContext().ConnectionStringName(\"testDBContext\", DbProviderTypes.SqlServer);
  4. }


2.)config中的连接字符串实例 

点击(此处)折叠或打开

  1. <connectionStrings>
  2.     <add name=\"testDBContext\" connectionString=\"server=192.168.1.100;uid=sa;pwd=sa!;database=testDB;\" />
  3.   </connectionStrings>

那么下面就可以在我们的数据业务层中根据自己的需求随心所欲的写sql了。 
1.需要返回一个实体: 

点击(此处)折叠或打开

  1. Product product = QueryDB().Sql(@\"select * from Product
  2.                 where ProductId = 1\").QuerySingle<Product>()

2.根据参数返回一个实体?别急,尝尝那飘渺的链式操作吧 

点击(此处)折叠或打开

  1. Product product = QueryDB().Sql(\"select * from Product where id=@id\")
  2.                   .Parameter(\"id\", id)
  3.                  .QuerySingle<Product>()

3.返回一个泛型。 

点击(此处)折叠或打开

  1. List<Product> product = QueryDB().Sql(\"select * from Product where id=@id\")
  2.                   .Parameter(\"id\", id)
  3.                  .Query<Product>()

4.多表支持(这个楼主实际工作中倒是没有用到过) 

点击(此处)折叠或打开

  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. }

5.插入操作 

点击(此处)折叠或打开

  1. var productId = QueryDB().Insert(\"Product\")
  2.                 .Column(\"Name\", \"The Warren Buffet Way\")
  3.                 .Column(\"CategoryId\", 1)
  4.                 .ExecuteReturnLastId()

6.当然我喜欢写我牛B的sql。 

点击(此处)折叠或打开

  1. var productId = QueryDB().Sql(@\"insert into Product(Name, CategoryId)
  2.                     values(\‘The Warren Buffet Way\‘, 1);\").ExecuteReturnLastId()

7.修改操作. 

点击(此处)折叠或打开

  1. QueryDB().Update(\"Product\")
  2.         .Column(\"Name\", \"The Warren Buffet Way\")
  3.         .Column(\"CategoryId\", 1)
  4.         .Where(\"ProductId\", 1)
  5.         .Execute()

同上,也可以不用update()方法,而直接写sql. 
8.删除操作 
QueryDB().Delete("Product").Where("ProductId", 1).Execute(); 
9.我想链式操作,我想写lambda表达式OK。 

点击(此处)折叠或打开

  1. QueryDB().Delete<Product>(\"Product\") 
  2.      .Where(x=>x.id,id)
  3.      .Execute()

10.事物的处理 

点击(此处)折叠或打开

  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. }

在事物的操作中记得context.Commit();方法的执行,楼主曾经在自己的一个项目中需要用到事物,却忘记了执行提交这个方法,最后在源码的汪 洋中探索许久 
11.存储过程 
有关存储过程的使用,楼主在实际项目开发中,用上了存储过程。该存储过程的作用是分页,那么这里也贴出来分享一下 

点击(此处)折叠或打开

  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>()


上面贴的都是一些方法内容,具体的可以用方法封装下,当然该ORM是基于Freamework4.0的,Idbcontext接口下的方法也有支持返回一个动态类型的,所以扩展性也不弱。具体的就在于灵活的运用。 
至此;写到这里一定很激动了吧,大伙有时间有机会的话,也去尝试下吧。 
 
八、提供资源下载 
 
关于NHibernate及EF在北风网官网上能找到我的教程,但关于FluentData的这个ORM框架的视频市面上虽有,却少,而且不系统完整,兼与此, 
我自己计划出一些关于FluentData的教学视频,已经在进行中,照例给出思维导图及已完成的视频,需了解更多的可以给我留言,希望我的付出对您有所帮助。 
技术分享

已经录制好的视频有如下十二讲,后面计划会结合具体的案例项目更深入的讲解
技术分享

本次先公开课程的前三讲及部分代码(说明:代码请用VS2012打开),供大家入门参考! 
 
链接:http://pan.baidu.com/s/1eQkV4VC
密码在原文,即下面链接中。
《FluentData - 轻量级.NET ORM持久化技术解决方案》 全文请查看:http://bbs.ibeifeng.com/read-htm-tid-66379.html 

快速上手如何使用FluentData

标签:

原文地址:http://www.cnblogs.com/zkwarrior/p/4783403.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!