导航

目   录:Farseer.net轻量级ORM开源框架 目录

上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射

下一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射

前言

  我们知道对于关系数据库,视图的出现可以在一定的情况下减少因要进行数据关联而带来的大量SQL语句,它可以让我们就像访问一张表一样的简单操作。

  作为ORM来说,支持视图也是一项最基础的工作。然而大部份的ORM中,对视图没有特意去提供这个类,因为视图的SQL与表的SQL是一致的,因此可以将视图当成表来访问操作。

  而在Farseer.Net里为视图提供了专门的类的目的是告诉开发者,它是一个只读“表”,仅读、而不能进行任何数据更新操作。

ViewSet

  在前一篇文章里,我们学会了视图的映射,其它它与表的映射是基本一致的。除了是使用:TableSet,视图使用的是ViewSet

  到目前为止,相信大家也知道了xxxSet的作用,就是为这些特定“表”、“视图”、“存储过程”提供它们专用的方法,以便我们对数据库进去操作。

  前面也讲到过ViewSetTableSet他们都继承了:DbReadSet<TSet, TEntity> 这个类

    /// <summary>
/// 视图操作
/// </summary>
/// <typeparam name="TEntity">实体</typeparam>
public sealed class ViewSet<TEntity> : DbReadSet<ViewSet<TEntity>, TEntity> where TEntity : class, new() /// <summary>
/// 表操作
/// </summary>
/// <typeparam name="TEntity"></typeparam>
public sealed class TableSet<TEntity> : DbReadSet<TableSet<TEntity>, TEntity> where TEntity : class, new()

  换句话说,他们都共同包含了DbReadSet提供的方法、属性

  在表的数据操作一篇中,已经讲到了如何进行操作一张表。包括了读数据、写数据这两类,而从字面理解上我们也知道了DbReadSet是为读数据提供的一个数据库操作类。

  因此视图的操作,就相当于是表的读操作那一部份。

  既然如此,那么很明显,它们的调用方式也是一样的。

静态调用方式
 // 在查询时,进行字段筛选,否则将以*号查询
View.Data.Account.Select(o=>o.ID).Select(o=>new {o.UserName,o.LoginCount});
// 查询或者更新时,限定条件
View.Data.Account.Where(o=>o.ID);
// 排序方式
View.Data.Account.Desc(o=>o.ID).Asc(o=>new {o.LoginCount,o.CreateAt});
View.Data.Account.Asc(o=>o.ID);
实例化调用
 using(var context = new View())
{
context.Account.Select(o=>new{ o.ID, o.UserName}).Where(o=>o.ID > ).Desc(o=>o.ID)
}
ViewSet提供的方法
        /// <summary> 查询多条记录(不支持延迟加载) </summary>
/// <param name="top">限制显示的数量</param>
/// <param name="isDistinct">返回当前条件下非重复数据</param>
/// <param name="isRand">返回当前条件下随机的数据</param>
public virtual DataTable ToTable(int top = , bool isDistinct = false, bool isRand = false) /// <summary> 查询多条记录(不支持延迟加载) </summary>
/// <param name="pageSize">每页显示数量</param>
/// <param name="pageIndex">分页索引</param>
/// <param name="isDistinct">返回当前条件下非重复数据</param>
/// <returns></returns>
public virtual DataTable ToTable(int pageSize, int pageIndex, bool isDistinct = false) /// <summary> 查询多条记录(不支持延迟加载) </summary>
/// <param name="pageSize">每页显示数量</param>
/// <param name="pageIndex">分页索引</param>
/// <param name="recordCount">总记录数量</param>
/// <param name="isDistinct">返回当前条件下非重复数据</param>
public virtual DataTable ToTable(int pageSize, int pageIndex, out int recordCount, bool isDistinct = false) /// <summary> 查询多条记录(不支持延迟加载) </summary>
/// <param name="top">限制显示的数量</param>
/// <param name="isDistinct">返回当前条件下非重复数据</param>
/// <param name="isRand">返回当前条件下随机的数据</param>
public virtual List<TEntity> ToList(int top = , bool isDistinct = false, bool isRand = false) /// <summary>
/// 查询多条记录(不支持延迟加载)
/// </summary>
/// <param name="pageSize">每页显示数量</param>
/// <param name="pageIndex">分页索引</param>
/// <param name="isDistinct">返回当前条件下非重复数据</param>
/// <returns></returns>
public virtual List<TEntity> ToList(int pageSize, int pageIndex, bool isDistinct = false) /// <summary>
/// 查询多条记录(不支持延迟加载)
/// </summary>
/// <param name="pageSize">每页显示数量</param>
/// <param name="pageIndex">分页索引</param>
/// <param name="recordCount">总记录数量</param>
/// <param name="isDistinct">返回当前条件下非重复数据</param>
public virtual List<TEntity> ToList(int pageSize, int pageIndex, out int recordCount, bool isDistinct = false) /// <summary>
/// 返回筛选后的列表
/// </summary>
/// <typeparam name="TEntity">实体类</typeparam>
/// <typeparam name="T">实体类的属性</typeparam>
/// <param name="select">字段选择器</param>
public virtual List<T> ToSelectList<T>(Expression<Func<TEntity, T>> select) /// <summary>
/// 返回筛选后的列表
/// </summary>
/// <param name="top">限制显示的数量</param>
/// <param name="select">字段选择器</param>
/// <typeparam name="TEntity">实体类</typeparam>
/// <typeparam name="T">实体类的属性</typeparam>
public virtual List<T> ToSelectList<T>(int top, Expression<Func<TEntity, T>> select) /// <summary>
/// 返回筛选后的列表
/// </summary>
/// <param name="select">字段选择器</param>
/// <param name="lstIDs">o => IDs.Contains(o.ID)</param>
/// <typeparam name="TEntity">实体类</typeparam>
/// <typeparam name="T">实体类的属性</typeparam>
/// <param name="memberName">条件字段名称,如为Null,默认为主键字段</param>
public virtual List<T> ToSelectList<T>(List<T> lstIDs, Expression<Func<TEntity, T>> select, string memberName = null) /// <summary>
/// 返回筛选后的列表
/// </summary>
/// <param name="select">字段选择器</param>
/// <param name="lstIDs">o => IDs.Contains(o.ID)</param>
/// <param name="top">限制显示的数量</param>
/// <typeparam name="TEntity">实体类</typeparam>
/// <typeparam name="T">实体类的属性</typeparam>
/// <param name="memberName">条件字段名称,如为Null,默认为主键字段</param>
public virtual List<T> ToSelectList<T>(List<T> lstIDs, int top, Expression<Func<TEntity, T>> select, string memberName = null) /// <summary>
/// 查询单条记录(不支持延迟加载)
/// </summary>
public virtual TEntity ToEntity() /// <summary>
/// 获取单条记录
/// </summary>
/// <typeparam name="T">ID</typeparam>
/// <param name="ID">条件,等同于:o=>o.ID.Equals(ID) 的操作</param>
/// <param name="memberName">条件字段名称,如为Null,默认为主键字段</param>
public virtual TEntity ToEntity<T>(T ID, string memberName = null) /// <summary>
/// 查询数量(不支持延迟加载)
/// </summary>
public virtual int Count(bool isDistinct = false, bool isRand = false) /// <summary>
/// 获取数量
/// </summary>
/// <typeparam name="T">ID</typeparam>
/// <param name="ID">条件,等同于:o=>o.ID.Equals(ID) 的操作</param>
/// <param name="memberName">条件字段名称,如为Null,默认为主键字段</param>
public virtual int Count<T>(T ID, string memberName = null) /// <summary>
/// 获取数量
/// </summary>
/// <typeparam name="T">ID</typeparam>
/// <param name="lstIDs">条件,等同于:o=> IDs.Contains(o.ID) 的操作</param>
/// <param name="memberName">条件字段名称,如为Null,默认为主键字段</param>
public virtual int Count<T>(List<T> lstIDs, string memberName = null) /// <summary>
/// 查询数据是否存在(不支持延迟加载)
/// </summary>
public virtual bool IsHaving() /// <summary>
/// 判断是否存在记录
/// </summary>
/// <typeparam name="T">ID</typeparam>
/// <param name="ID">条件,等同于:o=>o.ID == ID 的操作</param>
/// <param name="memberName">条件字段名称,如为Null,默认为主键字段</param>
public virtual bool IsHaving<T>(T ID, string memberName = null) /// <summary>
/// 判断是否存在记录
/// </summary>
/// <typeparam name="T">ID</typeparam>
/// <param name="lstIDs">条件,等同于:o=> IDs.Contains(o.ID) 的操作</param>
/// <param name="memberName">条件字段名称,如为Null,默认为主键字段</param>
public virtual bool IsHaving<T>(List<T> lstIDs, string memberName = null) /// <summary>
/// 查询单个值(不支持延迟加载)
/// </summary>
public virtual T GetValue<T>(Expression<Func<TEntity, T>> fieldName, T defValue = default(T)) /// <summary>
/// 查询单个值
/// </summary>
/// <typeparam name="T1">ID</typeparam>
/// <typeparam name="T2">字段类型</typeparam>
/// <param name="ID">条件,等同于:o=>o.ID.Equals(ID) 的操作</param>
/// <param name="fieldName">筛选字段</param>
/// <param name="defValue">不存在时默认值</param>
/// <param name="memberName">条件字段名称,如为Null,默认为主键字段</param>
public virtual T2 GetValue<T1, T2>(T1 ID, Expression<Func<TEntity, T2>> fieldName, T2 defValue = default(T2), string memberName = null) /// <summary>
/// 累计和(不支持延迟加载)
/// </summary>
public virtual T Sum<T>(Expression<Func<TEntity, T>> fieldName, T defValue = default(T)) /// <summary>
/// 查询最大数(不支持延迟加载)
/// </summary>
public virtual T Max<T>(Expression<Func<TEntity, T>> fieldName, T defValue = default(T)) /// <summary>
/// 查询最小数(不支持延迟加载)
/// </summary>
public virtual T Min<T>(Expression<Func<TEntity, T>> fieldName, T defValue = default(T))

  可以很清楚的看出,上面提供的方法均是读操作。而没有任何的写操作。同时这部份方法也是被TableSet支持的(又啰嗦了,照顾下新人)。

  比如我们获取一条数据是:

View.Data.Account.Select(o => o.ID).Select(o => o.Name).Where(o => o.ID > ).ToEntity();

  我们获取一批数据是:

View.Data.Account.Select(o => o.ID).Select(o => o.Name).Where(o => o.ID > ).Asc(o => o.ID).ToList();

  其它的就不再举例了。大家可以自行尝试下。

总结

  视图的方法,实际就是等同于表的读方法那部份,因此大家学会了表的操作之后,一样懂得如何操作视图(方法、参数一致)。

  由于Farseer.net暂时未提供复杂的SQL查询功能。因此用视图来进行转化下也是一种很方便的手段。

导航

目   录:Farseer.net轻量级ORM开源框架 目录

上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射

下一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射

广告时间

QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net

Farseer.Net是一款ORM框架 + 常用工具 + 扩展集合。

Farseer 寓意:先知、预言家 通常在某些场合时,提供计谋、策略。也希望该框架能给大家提供最大化的便捷。

ORM:其英文全称是:Object(对象) Relational(关系) Mapping(映射)

Farseer.Net的目标是:快速上手、快速开发、简单方便。

 Table.Data.User.Where(o=>o.ID == ).ToEntity();
Table.Data.User.Where(o=>o.ID > ).ToList();
Table.Data.User.Where(o=>o.ID != ).Delete();
Table.Data.User.Where(o=>o.ID != ).AddUp(o=>o.LoginCount, );
Table.Data.User.Where(o=>o.ID == ).Update(new User{ UserName = "newName" });
Table.Data.User.Insert(new User{ UserName = "newName" });

Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作的更多相关文章

  1. Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程数据操作

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射 下一篇:Farseer.net轻量级ORM ...

  2. Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作 下一篇:Farseer.net轻量级ORM开源 ...

  3. Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作 下一篇:Farseer.net轻量级ORM开源框 ...

  4. Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库上下文

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置文件 下一篇:Farseer.net轻量级ORM开源 ...

  5. Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射 下一篇:Farseer.net轻量级ORM开源框 ...

  6. Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库上下文 下一篇:Farseer.net轻量级ORM开源框 ...

  7. Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置文件

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:新版本说明 下一篇:Farseer.net轻量级ORM开源框架 ...

  8. Farseer.net轻量级ORM开源框架 V1.x 入门篇:新版本说明

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:没有了 下一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置 前言 V1.x版本终于到来了.本次 ...

  9. Farseer.net轻量级ORM开源框架 V1.x 教程目录

    本篇教程将以Ver 1.x版本进行详细使用讲解 大家有任何疑问可以加入我们的官方QQ群进行讨论.QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net 整个 ...

随机推荐

  1. github相关

    1 某次release的源码 某次release的源码在release列表中,不在branch中,tag和release是在一起的.所以,下载某个release的源码应该去release中找,而不应该 ...

  2. 8核 16g 及时释放内存空间

    del  释放 大变量 所在内存空间 GB数据

  3. JPEG库在Linux系统下的编译和移植【转】

    本文转载自: 这篇文章介绍了jpeg库在Linux系统下的编译和移植,经过了亲自的验证,编译首先需要准备以下资源:jpegsrc.v6b.tar.gz(jpeg库),libtool-1.5.26.ta ...

  4. HDU1281 棋盘游戏 —— 二分图最大匹配 + 枚举

    题目链接:https://vjudge.net/problem/HDU-1281 棋盘游戏 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit ...

  5. APP界面常用的五种颜色搭配

    众所周知,每一种颜色带给用户的视觉感受也是不同的.现在人们对手机的依赖程度,就能看到手机中APP的发展前景,那今天就跟大家聊聊如何通过颜色搭配的不同来进行移动端APP界面的布局和排版设计.移动端UI界 ...

  6. HDU - 1255 覆盖的面积(线段树求矩形面积交 扫描线+离散化)

    链接:线段树求矩形面积并 扫描线+离散化 1.给定平面上若干矩形,求出被这些矩形覆盖过至少两次的区域的面积. 2.看完线段树求矩形面积并 的方法后,再看这题,求的是矩形面积交,类同. 求面积时,用被覆 ...

  7. BZOJ_2819_Nim_树状数组维护出栈入栈序

    BZOJ_2819_Nim_树状数组维护出栈入栈序 Description 著名游戏设计师vfleaking,最近迷上了Nim.普通的Nim游戏为:两个人进行游戏,N堆石子,每回合可以取其中某一堆的任 ...

  8. bzoj3638

    费用流+线段树 看见这个题我们马上就能想到费用流,设立源汇,分别向每个点连接容量为1费用为0的边,然后相邻的点之间连边,费用为点权,跑费用流就行了,但是很明显这样会超时,那么我们要优化一下,我们观察费 ...

  9. 关于eclipse部署项目后,在tomcat中的webapps文件夹下没有项目

    转自:https://blog.csdn.net/yang505581644/article/details/78802316 一.发现问题 在eclipse中新建Dynamic Web Projec ...

  10. ASP.NET项目开发实战<<一键创建解决方案>>

    视频演示地址:http://www.youku.com/playlist_show/id_23192838.html 第一步:创建项目需要的数据库 打开辅助开发工具,如下图 从左侧菜单找到 项目数据库 ...