本文来自:http://fluentdata.codeplex.com/wikipage?title=Fluency&referringTitle=Home

Documentation  Fluency

This contribution is an attempt to speedup the development of domain layer in bottom to top model with FluentData. This means you already have the Database created and you need a quick way to write the Entity wrapers and common CURD operations. The goal of fluency is to provide T4 templates to generate a domain layer which has very minimal learning curve and very simple to use. At the moment Fluency supports the Table Data Gateway pattern which is very simple to understand and use.

How to use Fluency Templates?

The recommended way to use Fluency Template is by using TextTransform.exe tool. This is a command-line tool that you can use to transform a text template. When you call TextTransform.exe, you specify the name of a text template file as an argument. TextTransform.exe calls the text transformation engine and processes the text template. This tool accepts optional parameters in case your template requires some parameters which is the case with the template you will be using. TextTransform.exe is located in the following directory:

\Program Files\Common Files\Microsoft Shared\TextTemplating\10.0 
or
\Program Files\Common Files\Microsoft Shared\TextTemplating\11.0 

depending upon which version of visual studio you have. Also depending upon if you are using 64bit OS you may need to look under Program Files(X86) for the above location.

Adding new external tool

First of all you need to locate the TextTransform.exe as explained above. For my install since I am using Visual Studio 2010(32bit) on 64bit windows the location of TextTransform.exe is following
C:\Program Files (x86)\Common Files\Microsoft Shared\TextTemplating\10.0\TextTransform.exe

Now we have to do the following steps in order to add a new external tool under Visual Studio Tools menu.

  1. Copy Fluency folder from Contributions and move it under your Solution folder.
  2. Open Visual Studio and go to Tools -> External Tools menu and click Add button. This will add a blank external tool.
  3. In Title textbox enter Fluency while in Command textbox enter the full path to TextTransform.exe which in my case is C:\Program Files (x86)\Common Files\Microsoft Shared\TextTemplating\10.0\TextTransform.exe
  4. Now place following text in Arguments textbox
$(SolutionDir)\Fluency\TableDataGateway.tt -out  $(SolutionDir)/Entities.Generated.cs -a !!ns!MyDomain -a !!cs!Server=YOUR_SERVER_NAME;Database=MyDb;Trusted_Connection=true -a !!csn!MyDb
  • Here $(SolutionDir)\Fluency\TableDataGateway.tt is the path to template under your solution folder.
  • -out $(SolutionDir)/Entities.Generated.cs tells the path and name of generated file in your solution folder.
  • -a !!ns!MyDomain tells the template about namespace for generated code where !!ns is parameter name and !MyDomain tells value which is MyDomain.
  • -a !!cs!Server=YOUR_SERVER_NAME;Database=MyDb;Trusted_Connection=true tells the database connection string from where template has to generate the code.
  • Lastly -a !!csn!MyDb tells the name of connection string in web.config which will be used by generated code when opening a database connection. In this case connection string name is MyDb you will replace this with what ever is yours.

Now click OK button and new external tool will be added to your Tools menu. Finally open your Solution in Visual Studio and then go to Tools menu and click on Fluency. It will open a dialogue box just click on OK button and it will generate the code under you solutoin folder! Now that template is configured you can always regenerate your code in few clicks.

Understanding the generated code !!

There will be two classes generated for every table in database. First one will be entity class which will contain fields corrosponding to Database table. The second will be Gateway class which will contain common method for CURD operations. Lets suppose we have a table called Product in Database with following schema

        CREATE TABLE [dbo].[Product](
[Id] [int] IDENTITY(1,1) NOT NULL,
[Name] [nvarchar](256) NOT NULL,
[Price] [decimal](18, 2) NOT NULL,
[Sku] [nvarchar](256) NULL,
[Description] [nvarchar](max) NULL,
[ManufacturerId] [int] NULL,
[CreatedOn] [datetime] NULL,
[ModifiedOn] [datetime] NULL
CONSTRAINT [PK_Product] PRIMARY KEY CLUSTERED ([Id] ASC))

The code generated for product table will consist of following two classes

        /// <summary>
/// Product entity class
/// </summary>
public partial class Product
{
public int Id { get; set; }
public string Name { get; set; }
public decimal Price { get; set; }
public string Sku { get; set; }
public string Description { get; set; }
public int ManufacturerId { get; set; }
public DateTime CreatedOn { get; set; }
public DateTime ModifiedOn { get; set; }
} /// <summary>
/// Product gateway class
/// </summary>
public partial class ProductGateway
{
private static IDbContext Context()
{
return new DbContext().ConnectionStringName("MyDb",
new SqlServerProvider());
} public static Product Select(int id)
{
using(var context = Context())
{
return context.Sql(" SELECT * FROM Product WHERE Id = @id ")
.Parameter("id", id)
.QuerySingle<Product>();
}
} public static List<Product> SelectAll()
{
return SelectAll(string.Empty);
} public static List<Product> SelectAll(string sortExpression)
{
return SelectAll(0, 0, sortExpression);
} public static List<Product> SelectAll(int startRowIndex, int maximumRows, string sortExpression)
{
using (var context = Context())
{
var select = context.Select<Product>(" * ")
.From(" Product "); if (maximumRows > 0)
{
if (startRowIndex == 0)
startRowIndex = 1; select.Paging(startRowIndex, maximumRows);
} if (!string.IsNullOrEmpty(sortExpression))
select.OrderBy(sortExpression); return select.QueryMany();
}
} public static int CountAll()
{
using (var context = Context())
{
return context.Sql(" SELECT COUNT(*) FROM Product ")
.QuerySingle<int>();
}
} public static List<Product> SelectByManufacturer(int manufacturerId)
{
return SelectByManufacturer(manufacturerId, string.Empty);
} public static List<Product> SelectByManufacturer(int manufacturerId, string sortExpression)
{
return SelectByManufacturer(manufacturerId, 0, 0, sortExpression);
} public static List<Product> SelectByManufacturer(int manufacturerId, int startRowIndex, int maximumRows, string sortExpression)
{
using (var context = Context())
{
var select = context.Select<Product>(" * ")
.From(" Product ")
.Where(" ManufacturerId = @manufacturerid ")
.Parameter("manufacturerid", manufacturerId); if (maximumRows > 0)
{
if (startRowIndex == 0)
startRowIndex = 1; select.Paging(startRowIndex, maximumRows);
} if (!string.IsNullOrEmpty(sortExpression))
select.OrderBy(sortExpression); return select.QueryMany();
}
} public static int CountByManufacturer(int manufacturerId)
{
using (var context = Context())
{
return context.Sql(" SELECT COUNT(*) FROM Product WHERE ManufacturerId = @manufacturerid")
.Parameter("manufacturerid", manufacturerId)
.QuerySingle<int>();
}
} public static bool Insert(Product product)
{
using (var context = Context())
{
int id = context.Insert<Product>("Product", product)
.AutoMap(x => x.Id)
.ExecuteReturnLastId<int>(); product.Id = id;
return id > 0;
}
}
public static bool Update(Product product)
{
using (var context = Context())
{
return context.Update<Product>("Product", product)
.AutoMap(x => x.Id)
.Execute() > 0;
}
} public static bool Delete(Product product)
{
return Delete(product.Id);
} public static bool Delete(int id)
{
using (var context = Context())
{
return context.Sql(" DELETE FROM Product WHERE Id = @id ")
.Parameter("id", id)
.Execute() > 0;
}
}
}

Select single product by Id

        Product product = ProductGateway.Select(103);

Select all products

        List<Product> products = ProductGateway.SelectAll();

Count all products

        int count = ProductGateway.CountAll();

Select all products with paging

        // LOAD FIRST 20 PRODUCTS ORDER BY ID
List<Product> products = ProductGateway.SelectAll(1, 20, "Id ASC");

Select all products for manufacturer foreign key

        // LOAD FIRST 20 PRODUCTS ORDER BY NAME FOR MANUFACTURER ID 91
List<Product> products = ProductGateway.SelectByManufacturer(91,1, 20, "Name ASC");

Insert new product

            Product product = new Product() { Name = "New Product", Price = 111, Sku = "SKU-111", Description = "None" };
ProductGateway.Insert(product); // IF PRIMARYKEY IS IDENTITY THEN IT WILL BE SET BACK TO THE OBJECT
Console.Writeline(string.Format("Product Id = {0}", product.Id));

Update existing product

        Product product = ProductGateway.Select(103);
product.Price = 200;
ProductGateway.Update(product);

Delete existing product

        Product product = ProductGateway.Select(103);
ProductGateway.Delete(product);
 

Last edited Jun 25, 2013 at 6:55 AM by leadfoot, version 28

[转]FluentData的更多相关文章

  1. FluentData(微型ORM)

    using FluentData; using System; using System.Collections.Generic; using System.Linq; using System.Te ...

  2. 在不安装mysql-connector-net的情况下使用FluentData框架

    最近在开发项目中使用了FluentData框架,通过使用这个框架减少了很多开发的工作量,FluentData是一个轻量级的框架操作起来的自由度很大也少了很多负责的配置.但是在开发的时候发现一个问题就是 ...

  3. 微型orm fluentdata

    http://fluentdata.codeplex.com/documentation#Query

  4. FluentData Mysql分页的一个BUG

    开发环境 FluentData3.0.VS.NET2010.Mysql5.0 问题描述 使用FluentData对一个表(记录数28)进行分页时,突然发现一个诡异的问题,第一页返回10条数据正常,第二 ...

  5. FluentData,它是一个轻量级框架,关注性能和易用性。

    http://www.cnblogs.com/zengxiangzhan/p/3250105.html FluentData,它是一个轻量级框架,关注性能和易用性. 下载地址:FlunenData.M ...

  6. 快速上手如何使用FluentData

    http://blog.itpub.net/29511780/viewspace-1194048/ 目录:  一.什么是ORM? 二.使用ORM的优势 三.使用ORM的缺点 四.NET下的ORM框架有 ...

  7. FluentData官方文档翻译

    开始 要求 .NET 4.0. 支持的数据库 MS SQL Server using the native .NET driver. MS SQL Azure using the native .NE ...

  8. FluentData微型ORM

    最近在帮朋友做一个简单管理系统,因为笔者够懒,但是使用过的NHibernate用来做这中项目又太不实际了,索性百度了微型ORM,FluentData是第一个跳入我眼睛的词.简单的了解下FluentDa ...

  9. Oracle+FluentData+MVC4+EasyUI开发权限管理系统之开篇

    在园子里有很多EF+MVC+EasyUI的框架实在是太多了,经过在一段时间的学习高手写的思路,但是都是针对Sql数据的,但是今年我当上研发组组长的第一个任务就是编写一个通用平台框架,一刚开始想把学习过 ...

  10. orm fluentdata使用相关文章

    微型orm fluentdata使用:http://www.360doc.com/content/12/1228/23/9200790_256885743.shtml

随机推荐

  1. 谷歌开发者工具(F12)的使用小坑

    python模拟登陆知乎,用开发者工具跟踪浏览器与服务器的交互,需要知道用户名,密码的字段名,可在文件email中看到:需要注意的是一定要 勾选 preserve log ,否则登陆之前的交互不会显示 ...

  2. Qt5获取网卡/IP等信息

    参考网址:http://blog.csdn.net/wjs1033/article/details/22697063 1.环境 Win7x64.Qt5.5.1(x86).vs2013_ultimate ...

  3. Tensorflow一些常用基本概念与函数(二)

    1.tensorflow的基本运作 为了快速的熟悉TensorFlow编程,下面从一段简单的代码开始: import tensorflow as tf #定义‘符号’变量,也称为占位符 a = tf. ...

  4. 雷林鹏分享:Ruby 正则表达式

    Ruby 正则表达式 正则表达式是一种特殊序列的字符,它通过使用有专门语法的模式来匹配或查找其他字符串或字符串集合. 语法 正则表达式从字面上看是一种介于斜杠之间或介于跟在 %r 后的任意分隔符之间的 ...

  5. C#通过WMI读取MAC地址

    该方法依赖WMI的系统服务,该服务一般不会被关闭;但如果系统服务缺失或者出现问题,该方法无法取得MAC地址,需要重启Windows Management Instrumentation服务. publ ...

  6. Linux网络编程--洪水攻击详解

    洪水攻击详解 ①注解:洪水攻击(FLOOD ATTACK)是指利用计算机网络技术向目标主机发送大量无用的数据报文,使得目标主机忙于处理无用的数据报文而无法提供正常服务的网络行为. 主要原理:利用了网络 ...

  7. web 移动端事件总结

    1.https://www.jianshu.com/p/6f85e957a725 (web 移动端事件总结)

  8. 将java打jar包成linux后台服务service

    将java打jar包成linux后台服务service 第一步:将java程序打成jar包 build.gradle配置文件中加spring-boot-gradle-plugin插件,具体配置如下(配 ...

  9. CentOS7 Could not retrieve mirrorlist http://mirrorlist.centos.org/?...

    在执行命令 sudo yum clean expire-cache 清理完过期的缓存后,再执行yum install 或 update命令都失败了.原因是清理过期缓存结果不该被清理的也删掉了,可能是y ...

  10. easyui combotree 异步树 前端写法js

    简要说下使用场景: combotree下拉框第一次加载时,请求一个接口,页面上展示顶层节点们(可以理解为最顶层的节点,比如所有的一级公司): 当点击其中一个节点前面的小三角展开时,再次请求服务器接口( ...