Farseer.net轻量级开源框架 入门篇:查询数据详解

导航

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

上一篇:Farseer.net轻量级开源框架 入门篇: 删除数据详解

查询列表的几种方式

1         // 字段值指定 加 1
2         Users.Data.Where(o => o.ID == 1).ToList();
1         // 查询前10条数据
2         Users.Data.ToList(10);
1         // 批量查询
2         var lst = new List<int> { 1, 2, 3, 4, 5 };
3         Users.Data.ToList(lst);
1         // 查询第2页,每页显示20条(分页)
2         Users.Data.ToList(20, 2);
1         // 查询第5页,每页显示10条(分页)
2         int recordCount;    // 记录总数
3         Users.Data.ToList(out recordCount, 10, 5);
1         // 减少数据库压力,只显示UserName、PassWord字段
2         Users.Data.Select(o => new { o.UserName, o.PassWord }).ToList();
1         // 模糊搜索 + 高级搜索
2         var keywords = "";
3         var bean = Users.Data;  //  也可以是: var bean = User.Data.Select(o => new { o.UserName, o.PassWord })
4         bean.Where(o => o.ID > 1);
5         if (keywords.IsHaving()) { bean.Where(o => o.UserName.Contains(keywords)); }    // 当Keywords有值时,进行模糊搜索
6         // 可以加入   或者  的操作
7         bean.WhereOr(o => o.RoleID == 2);
8         var lst = bean.ToList();
1         // 如果你嫌ToList 慢(反射到实体,也可以只返回DataTable
2         Users.Data.ToTable();
1         // 批量查询,按ID降序
2         Users.Data.Desc(o => o.ID).ToList();
3
4         // 批量查询,按ID、UserName 升序
5         Users.Data.Asc(o => new { o.ID,o.UserName }).ToList();
1         // 返回随机记录
2         Users.Data.ToListByRand();
1         // 这里返回的结果不是实体了,是标识ID列表。
2         // 比如可能返回的是:1,2,3,4
3         Users.Data.ToSelectList();

查询单条记录的几种方式

1         // 查找ID == 1 的单条记录
2         Users.Data.ToInfo(1);
1         // ID 为 1 的下一条数据(通常是下一篇文章的概念)
2         Users.Data.ToNextInfo(1);
1         // ID 为 2 的上一条数据(通常是上一篇文章的概念)
2         Users.Data.ToPreviousInfo(2);

查询单值、聚集的几种方式

1         // 返回记录总数
2         Users.Data.Where(o => o.ID > 6).Count();
1         // 返回最大的ID
2         Users.Data.GetMax(o => o.ID);
1         // 返回ID最小的数
2         Users.Data.GetMin(o => o.ID);
1         // 返回ID的累加数
2         Users.Data.GetSum(o => o.ID);
1         // 返回用户名(这里是字符串类型了)
2         Users.Data.GetValue(o => o.UserName);
1         // 判断值是否存在
2         Users.Data.Where(o => o.ID == 1).IsHaving();

导航

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

上一篇:Farseer.net轻量级开源框架 入门篇: 删除数据详解

时间: 2024-10-14 12:59:32

Farseer.net轻量级开源框架 入门篇:查询数据详解的相关文章

Farseer.net轻量级开源框架 入门篇:Where条件的终极使用

导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 查询数据详解 下一篇:Farseer.net轻量级开源框架 中级篇: 事务的使用 这里,我把一些常用Where用到的条件都写在这里,方便大家学习 1 // 这是最常用的 属性判断 2 Users.Data.Where(o => o.ID == 1) 3 Users.Data.Where(o => o.ID > 1) 4 Users.Data.Where(o => o

Farseer.net轻量级开源框架 入门篇:删除数据详解

导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 修改数据详解 下一篇:Farseer.net轻量级开源框架 入门篇: 查询数据详解 相对于修改,删除则简单的多: 1 // 字段值指定 加 1 2 Users.Data.Where(o => o.ID == 1).Delete(); 1 Users.Data.Delete(1); 1 var lst = new List<int> { 1, 2, 3, 4, 5 }; 2

Farseer.net轻量级开源框架 入门篇:分类逻辑层

导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 缓存逻辑层 下一篇:Farseer.net轻量级开源框架 入门篇: 添加数据详解 分类逻辑层 分类逻辑层,主要用在一些需要支持无限递归的树数据.树数据是:必须有一个根节点,根节点有无限个子节点,没有节点限制.比如我们常用的有:(频道.xxx分类) 这里与BaseCacheModel的操作是完全一致.唯一不同的是,BaseCateModel是继承自ModelCateInfo.这个类

Farseer.net轻量级开源框架 入门篇:事务的使用中级篇

导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 查询数据详解 下一篇:Farseer.net轻量级开源框架 中级篇: 执行SQL语句 DbExecutor 的使用 使用事务,我们需要用到一个类:DbExecutor 它的命名空间在:FS.Core.Data 中,我们先看下它的参数: 1 /// <summary> 2 /// 构造函数 3 /// </summary> 4 /// <param name=&

Farseer.net轻量级开源框架 入门篇:逻辑层的选择

导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 入门篇:增.删.改.查操作演示 下一篇:Farseer.net轻量级开源框架 入门篇: 实体类 当我们创建了一个实体类后,就需要继承其中一个基类:BaseModel.BaseCacheModel.BaseCateModel.只有继承了这三个基类的其中一个时,框架才能对实体建立数据库关系映射(也就是ORM).并且实现了对数据库的CURD的操作. 本框架与其它一些框架不同之处在于,对

Farseer.net轻量级开源框架 入门篇:使用前说明

导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 框架性能测试 下一篇:Farseer.net轻量级开源框架 入门篇: 增.删.改.查操作演示 本篇讲解使用或者学习Farseer前需要知道一些事项: 在后续很多演示中,使用了很多扩展方法.但作者并没有明确出哪些是扩展的方法.所以读者要注意.在使用框架的时候,都需要引用扩展方法的命名空间:using FS.Extend; 为了方便,扩展方法统一放到FS.Extend中,在这里特别说

Farseer.net轻量级开源框架 入门篇:修改数据详解

导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 添加数据详解 下一篇:Farseer.net轻量级开源框架 入门篇: 删除数据详解 Update的几种方式(基本) 1 Users info = new Users(); 2 info.UserName = "张三"; 3 info.PassWord = "密码"; 4 5 // 指定用户ID为1的的数据进行修改. 6 Users.Data.Wher

Farseer.net轻量级开源框架 入门篇:添加数据详解

导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 分类逻辑层 下一篇:Farseer.net轻量级开源框架 入门篇: 修改数据详解 前面讲的大多数是原理及说明,大家在理解上会比较枯燥,接下来的几篇,倾向于实战,会比较有意思些. 这里的话,还是拿Users实体类来讲解在我们框架的几种添加方式. Insert的几种方式 1 Users info = new Users(); 2 info.UserName = "张三";

Farseer.net轻量级开源框架 中级篇:动态数据库访问

导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 自定义配置文件 下一篇:Farseer.net轻量级开源框架 中级篇: 数据库切换 说到动态数据库的访问,不得不说的是,我们的实体类,是如何找到数据库配置并访问的呢? 回顾下我们的Users类: 1 [DB(Name = "Members_User")] 2 public class Users : BaseModel<Users>; 这里有个DB的特性,其