fluentdata 访问mysql_快速上手如何使用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

点击(此处)折叠或打开

publicstatic IDbContext QueryDB()

{

return new DbContext().ConnectionStringName(\"testDBContext\",DbProviderTypes.SqlServer);

}

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

点击(此处)折叠或打开

那么下面就可以在我们的数据业务层中根据自己的需求随心所欲的写sql了。

1.需要返回一个实体:

点击(此处)折叠或打开

Product product=QueryDB().Sql(@\"select * from Product

where ProductId = 1\").QuerySingle()

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

点击(此处)折叠或打开

Product product=QueryDB().Sql(\"select * from Product where id=@id\")

.Parameter(\"id\",id)

.QuerySingle()

3.返回一个泛型。

点击(此处)折叠或打开

Listproduct=QueryDB().Sql(\"select * from Product where id=@id\")

.Parameter(\"id\",id)

.Query()

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

点击(此处)折叠或打开

using(var command=QueryDB().MultiResultSql())

{

Listcategories=command.Sql(

@\"select * from Category;

select * from Product;\").Query();

Listproducts=command.Query();

}

5.插入操作

点击(此处)折叠或打开

var productId=QueryDB().Insert(\"Product\")

.Column(\"Name\",\"The Warren Buffet Way\")

.Column(\"CategoryId\",1)

.ExecuteReturnLastId()

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

点击(此处)折叠或打开

var productId=QueryDB().Sql(@\"insert into Product(Name, CategoryId)

values(\'The Warren Buffet Way\', 1);\").ExecuteReturnLastId()

7.修改操作.

点击(此处)折叠或打开

QueryDB().Update(\"Product\")

.Column(\"Name\",\"The Warren Buffet Way\")

.Column(\"CategoryId\",1)

.Where(\"ProductId\",1)

.Execute()

同上,也可以不用update()方法,而直接写sql.

8.删除操作

QueryDB().Delete("Product").Where("ProductId", 1).Execute();

9.我想链式操作,我想写lambda表达式OK。

点击(此处)折叠或打开

QueryDB().Delete(\"Product\")

.Where(x=>x.id,id)

.Execute()

10.事物的处理

点击(此处)折叠或打开

using(var context=QueryDB().UseTransaction)

{

context.Sql(\"update Product set Name = @0 where ProductId = @1\")

.Parameters(\"The Warren Buffet Way\",1)

.Execute();

context.Sql(\"update Product set Name = @0 where ProductId = @1\")

.Parameters(\"Bill Gates Bio\",2)

.Execute();

context.Commit();

}

在事物的操作中记得context.Commit();方法的执行,楼主曾经在自己的一个项目中需要用到事物,却忘记了执行提交这个方法,最后在源码的汪 洋中探索许久

11.存储过程

有关存储过程的使用,楼主在实际项目开发中,用上了存储过程。该存储过程的作用是分页,那么这里也贴出来分享一下

点击(此处)折叠或打开

publicstatic ListgetPage(string tableName,string tableFields,string sqlWhere,string order,intpageIndex,intpageSize,outinttotal)

{

var store=QueryDB().StoredProcedure(\"PF_Sys_PageControl\")

.ParameterOut(\"totalPage\",DataTypes.Int16)

.Parameter(\"tableName\",tableName)

.Parameter(\"tableFields\",tableFields)

.Parameter(\"sqlWhere\",sqlWhere)

.Parameter(\"orderFields\",order)

.Parameter(\"pageSize\",pageSize)

.Parameter(\"pageIndex\",pageIndex);

var result=store.Query()

上面贴的都是一些方法内容,具体的可以用方法封装下,当然该ORM是基于Freamework4.0的,Idbcontext接口下的方法也有支持返回一个动态类型的,所以扩展性也不弱。具体的就在于灵活的运用。

至此;写到这里一定很激动了吧,大伙有时间有机会的话,也去尝试下吧。

八、提供资源下载

关于NHibernate及EF在北风网官网上能找到我的教程,但关于FluentData的这个ORM框架的视频市面上虽有,却少,而且不系统完整,兼与此,

我自己计划出一些关于FluentData的教学视频,已经在进行中,照例给出思维导图及已完成的视频,需了解更多的可以给我留言,希望我的付出对您有所帮助。

29511780_1403748263gHpS.png

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

29511780_1403748280BOMb.png

本次先公开课程的前三讲及部分代码(说明:代码请用VS2012打开),供大家入门参考!

链接:http://pan.baidu.com/s/1eQkV4VC

密码在原文,即下面链接中。

《FluentData - 轻量级.NET ORM持久化技术解决方案》 全文请查看:http://bbs.ibeifeng.com/read-htm-tid-66379.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值