快速上手如何使用FluentData

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 [email protected]\")
  2. .Parameter(\"id\", id)
  3. .QuerySingle<Product>()

3.返回一个泛型。

点击(此处)折叠或打开

  1. List<Product> product = QueryDB().Sql(\"select * from Product where [email protected]\")
  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

时间: 2024-08-24 03:45:48

快速上手如何使用FluentData的相关文章

Extjs视频教程_快速上手Extjs4.2实战开发

Extjs视频教程_快速上手Extjs4.2实战开发快速上手Extjs4.2并熟练搭建基于MVC4+FluentData+Spring.net和T4模板的企业级项目架构适合人群:中级课程分类:.NET+ExtJs课时数量:76课时用到技术:Extjs4.2,MVC4,FluentData,T4,Spring.net涉及项目:基于Extjs4.2的丰富案例.一个独立的企业级架构和综合演示案例咨询qq:1840215592 Extjs视频教程课程大纲:(1)Extjs4.2理论部分(风舞烟老师老师主

R语言快速上手入门

R语言快速上手入门 课程学习网址:http://www.xuetuwuyou.com/course/196 课程出自学途无忧网:http://www.xuetuwuyou.com 课程简介 本教程深入浅出地讲解如何使用R语言玩转数据.课程中涵盖R语言编程的方方面面,内容涉及R对象的类型.R的记号体系和环境系统.自定义函数.if else语句.for循环.S3类R的包系统以及调试工具等.本课程还通过示例演示如何进行向量化编程,从而对代码进行提速并尽可能地发挥R的潜能.本课程适合立志成为数据科学家的

Power BI教程_Power BI数据分析快速上手及案例实战

Power BI数据分析快速上手及案例实战 课程学习地址:http://www.xuetuwuyou.com/course/194 课程出自学途无忧网:http://www.xuetuwuyou.com 课程简介 本课程在<Power BI 数据分析快速上手>基础上结合大量的实例,深入讲解PowerBI中看似难懂的各种概念.操作, 并结合行业中的典型案例贯穿了从初级的数据透视表工具.数据透视表选项.数据透视表的刷新.数据透视表中的排序,到中级的动 态数据透视表的创建.数据透视表函数 GETPI

《Python编程快速上手 让繁琐工作自动化》pdf

<div id="article_content" class="article_content tracking-ad" data-mod="popu_307" data-dsm="post"> <p><br></p><p>下载地址:<a target="_blank" href="https://page74.ctfile.co

下载快速上手数据挖掘之solr搜索引擎高级教程(Solr集群、KI分词、项目实战)

Solr是一个高性能,采用Java开发,基于Lucene的全文搜索服务器.同时对其进行了扩展,提供了比Lucene更为丰富的查询语言,同时实现了可配置.可扩展并对查询性能进行了优化,并且提供了一个完善的功能管理界面,是一款非常优秀的全文搜索引擎. 快速上手数据挖掘之solr搜索引擎高级教程(Solr集群.KI分词.项目实战),刚刚入手,转一注册文件,视频的确不错,可以先下载看看:http://pan.baidu.com/s/1jIdgtWM 密码:s1t3

Masonry介绍与使用实践:快速上手Autolayout

以上是纯手写代码所经历的关于页面布局的三个时期 在iphone1-iphone3gs时代 window的size固定为(320,480) 我们只需要简单计算一下相对位置就好了 在iphone4-iphone4s时代 苹果推出了retina屏 但是给了码农们非常大的福利:window的size不变 在iphone5-iphone5s时代 window的size变了(320,568) 这时autoresizingMask派上了用场(为啥这时候不用Autolayout? 因为还要支持ios5呗) 简单

MongoDB快速上手

1.  MongoDB简介 MongoDB是一个跨平台的基于Key_Value键值对形式保存数据的NoSQL文档类型数据库. NoSQL(not only sql)数据库,泛指非关系型数据库. 1.1 NoSQL数据库的特点 l  不需要预定义模式 不需要事先定义数据模式,预定义表结构.数据中的每条记录都可能有不同的属性和格式.当插入数据时,并不需要预先定义它们的模式. l  无共享架构 相对于将所有数据存储的存储区域网络中的全共享架构.NoSQL往往将数据划分后存储在各个本地服务器上.因为从本

intellij idea 13&amp;14 插件推荐及快速上手建议 (已更新!)

原文:intellij idea 13&14 插件推荐及快速上手建议 (已更新!) 早些年 在外企的时候,公司用的是intellij idea ,当时也是从eclipse.MyEclipse转过去的很是不习惯. 用了一周明显感觉爱上它了.因为它很智能,而且能纠正你很多不好的习惯. 后来跳巢到一家上市公司.因为大家都在用MyEclipse,要求开发工具统一.没办法只能转回MyEclipse.不过个人倒是一直关注intellij idea版本的发布和新的功能. 最近开始使用intellij idea

AJAX快速上手

创建XMLHttpRequest对象 xmlHttp = new XMLHttpRequest(); xmlHttp = new ActiveXObject('Microsoft.XMLHTTP');//IE XMLHttpRequest对象相关方法 打开请求 XMLHttpRequest.open(传递方式,地址,是否异步请求) 准备就绪执行 XMLHttpRequest.onreadystatechange 获取执行结果 XMLHttpRequest.responseText 上手小实践 /