DbContext、DbSet及DbQuery是Entity Framework Code First引入的3个新的类,其中DbContext用于保持数据库会话连接,实体变化跟踪及保存,DbSet用于暂存实体类的变化跟踪,DbQuery用于提供查询跟你。

  1、使用Set查询全部记录

  使用DbContext查询首先需要保证DbContext的实例在使用完之后对资源的释放,释放DbContext实例资源的方法有两种:采用using代码块结构和调用DbContext实例的Dispose()方法。

using (var ctx = new PortalContext())
{
foreach (var province in ctx.Provinces)
{
Console.WriteLine(province.ProvinceName);
}
}
using (var ctx = new PortalContext())
{
foreach (var province in ctx.Set<Province>())
{
Console.WriteLine(province.ProvinceName);
}
}

  2、使用LINQ排序、筛选等

  1>、LINQ排序

  LINQ表达式排序:

using (var ctx = new PortalContext())
{
var provinces = from p in ctx.Provinces
orderby p.ProvinceNo
select p;
foreach (var province in provinces)
{
Console.WriteLine(province.ProvinceName);
}
}

  LINQ表达式多字段排序:

using (var ctx = new PortalContext())
{
var provinces = from p in ctx.Provinces
orderby p.ProvinceNo descending, p.ProvinceName ascending
select p;
foreach (var province in provinces)
{
Console.WriteLine(province.ProvinceName);
}
}

  LINQ扩展方法排序:

using (var ctx = new PortalContext())
{
var provinces = ctx.Provinces
.OrderBy(p => p.ProvinceNo); foreach (var province in provinces)
{
Console.WriteLine(province.ProvinceName);
}
}

  LINQ扩展方法多字段排序:

var provinces = ctx.Provinces
.OrderByDescending(p => p.ProvinceNo)
.ThenBy(p => p.ProvinceName); foreach (var province in provinces)
{
Console.WriteLine(province.ProvinceName);
}

  注:在采用LINQ扩展方法进行多字段排序时,多出现多个OrderBy,则只按最后一个OrderBy字段进行排序。

  如下示例只会按照ProvinceName进行升序排序:

var provinces = ctx.Provinces
.OrderByDescending(p => p.ProvinceNo)
.OrderBy(p => p.ProvinceName);

  2>、LINQ筛选

  LINQ表达式筛选:

using (var ctx = new PortalContext())
{
var cities = from c in ctx.Cities
where c.ProvinceID ==
select c; foreach (var city in cities)
{
Console.WriteLine(city.CityName);
}
}

  LINQ表达式多字段筛选:

using (var ctx = new PortalContext())
{
var cities = from c in ctx.Cities
where c.ProvinceID == && c.CityID >
select c; foreach (var city in cities)
{
Console.WriteLine(city.CityName);
}
}

  LINQ表达式筛选与排序:

using (var ctx = new PortalContext())
{
var cities = from c in ctx.Cities
where c.ProvinceID == && c.CityID >
orderby c.CityID
select c; foreach (var city in cities)
{
Console.WriteLine(city.CityName);
}
}

  LINQ扩展方法筛选:

using (var ctx = new PortalContext())
{
var cities = ctx.Cities
.Where(c => c.ProvinceID == ); foreach (var city in cities)
{
Console.WriteLine(city.CityName);
}
}

  LINQ扩展方法多字段筛选:

using (var ctx = new PortalContext())
{
var cities = ctx.Cities
.Where(c => c.ProvinceID == && c.ProvinceID > ); foreach (var city in cities)
{
Console.WriteLine(city.CityName);
}
}

  LINQ扩展方法多字段筛选及排序:

var cities = ctx.Cities
.Where(c => c.ProvinceID == && c.ProvinceID > )
.OrderBy(c=>c.CityID);

  3>、LINQ选择读取字段

  LINQ表达式读取1个字段:

var cities = from c in ctx.Cities
where c.ProvinceID == && c.CityID >
select c.CityName;

  LINQ表达式读取多个字段:

var cities = from c in ctx.Cities
where c.ProvinceID == && c.CityID >
select new { c.CityID, c.CityName };

  LINQ扩展方法读取1个字段:

using (var ctx = new PortalContext())
{
var citieNames = ctx.Cities
.Where(c => c.ProvinceID == && c.ProvinceID > )
.OrderBy(c => c.CityID)
.Select(c => c.CityName); foreach (var cityName in citieNames)
{
Console.WriteLine(cityName);
}
}

  LINQ扩展方法读取多个字段:

using (var ctx = new PortalContext())
{
var cities = ctx.Cities
.Where(c => c.ProvinceID == && c.ProvinceID > )
.OrderBy(c => c.CityID)
.Select(c => new { c.CityID, c.CityName }); foreach (var c in cities)
{
Console.WriteLine("{0}-{1}", c.CityID, c.CityName);
}
}

  3、查询本地数据

  Entity Framework Code First通过DbSet的Local属性查询本地数据,查询本地数据的使用情况:1>当需要查询的数据已经存在与内存中,而不想再次发送SQL语句到数据库中取查询;2>当最新的数据还只在内存中而未提交到数据库的情况对内存数据进行查询。

  示例:初始时本地未加载内存数据

using (var ctx = new PortalContext())
{
var count = ctx.Cities.Local.Count;
Console.WriteLine("Cities in memory:{0}", count);
}

  执行后返回的结果:

  Cities in memory:0

  示例:先通过查询,将数据加载到内存

using (var ctx = new PortalContext())
{
foreach (var city in ctx.Cities)
{
Console.WriteLine(city.CityName);
} var count = ctx.Cities.Local.Count;
Console.WriteLine("Cities in memory:{0}", count);
}

  执行后返回的结果:

  ......

  Cities in memory:342

  3.2>、使用Load方法将数据加载到内存

using (var ctx = new PortalContext())
{
ctx.Cities.Load();
var count = ctx.Cities.Local.Count;
Console.WriteLine("Cities in memory:{0}", count);
}

  执行后的结果:

  Cities in memory:342

using (var ctx = new PortalContext())
{
var expr = from c in ctx.Cities
select c;
expr.Load();
var count = ctx.Cities.Local.Count;
Console.WriteLine("Cities in memory:{0}", count);
}

  3.2>、基于本地数据进行查询

using (var ctx = new PortalContext())
{
ctx.Cities.Load();
var cities = from c in ctx.Cities.Local
orderby c.ProvinceID
select c;
foreach (var city in cities)
{
Console.WriteLine("{0}", city.CityName);
}
}

  清除内存数据:

ctx.Cities.Local.Clear();

  4、查询单个对象

  DbContext API可以使用DbSet.Find来查询返回单个对象,DbSet.Find接受的参数值为需要查询的主键值,若未找到符合条件的主键值则返回null。

  Find查找单个对象的规则:

  1>、从内存中查找已经存在的从数据库中加载出来的实体或已经被附加到DbContext的实体;

  2>、查找新添加的但还未被提交保存到数据库中的实体对象;

  3>、到数据库中取查找还未加载到内存中的实体对象。

using (var ctx = new PortalContext())
{
var city = ctx.Cities.Find(); if (city != null)
{
Console.WriteLine(city.CityName);
}
else
{
Console.WriteLine("City not found!");
}
}

  若实体类具有多个主键,则Find方法同样接受全部主键的参数值,参数的顺序必须与主键列的顺序相同。

var city = ctx.Cities.Find(keyID, cityID);

  Single方法也可以用于查询后返回单个对象:

using (var ctx = new PortalContext())
{
var expr = from c in ctx.Cities
where c.CityID ==
select c; var city = expr.Single();
}

  SingleOrDefault方法查询返回单个对象:

using (var ctx = new PortalContext())
{
var expr = from c in ctx.Cities
where c.CityID ==
select c;
var city = expr.SingleOrDefault();
if (city != null)
{
Console.WriteLine(city.CityName);
}
else
{
Console.WriteLine("City not found!");
}
}

  Single与SingleOrDefault方法的区别在于:当不存在满足条件的单个实体时,Single将直接抛出异常,而SingleOrDefault则返回class类型的默认值null。

Entity Framework Code First使用DbContext查询的更多相关文章

  1. Entity Framework Code First学习系列目录

    Entity Framework Code First学习系列说明:开发环境为Visual Studio 2010 + Entity Framework 5.0+MS SQL Server 2012, ...

  2. Entity Framework Code First学习系列

    Entity Framework Code First学习系列目录 Entity Framework Code First学习系列说明:开发环境为Visual Studio 2010 + Entity ...

  3. Entity Framework Code First实体对象变动跟踪

    Entity Framework Code First通过DbContext.ChangeTracker对实体对象的变动进行跟踪,实现跟踪的方式有两种:变动跟踪快照和变动跟踪代理. 变动跟踪快照:前面 ...

  4. Entity Framework Code First关系映射约定

    本篇随笔目录: 1.外键列名默认约定 2.一对多关系 3.一对一关系 4.多对多关系 5.一对多自反关系 6.多对多自反关系 在关系数据库中,不同表之间往往不是全部都单独存在,而是相互存在关联的.两个 ...

  5. Entity Framework Code First执行SQL语句、视图及存储过程

    1.Entity Framework Code First查询视图 Entity Framework Code First目前还没有特别针对View操作的方法,但对于可更新的视图,可以采用与Table ...

  6. Entity Framework Code First主外键关系映射约定

    本篇随笔目录: 1.外键列名默认约定 2.一对多关系 3.一对一关系 4.多对多关系 5.一对多自反关系 6.多对多自反关系 在关系数据库中,不同表之间往往不是全部都单独存在,而是相互存在关联的.两个 ...

  7. 使用 Entity Framework Code First

    使用 Entity Framework Code First 在家闲着也是闲着,继续写我的[ASP.NET MVC 小牛之路]系列吧.在该系列的上一篇博文中,在显示书本信息列表的时候,我们是在程序代码 ...

  8. Entity Framework Code First实现乐观并发

    Entity Framework Code First实现乐观并发 不定时更新翻译系列,此系列更新毫无时间规律,文笔菜翻译菜求各位看官老爷们轻喷,如觉得我翻译有问题请挪步原博客地址 本博文翻译自: h ...

  9. Entity Framework Code first(转载)

    一.Entity Framework Code first(代码优先)使用过程 1.1Entity Framework 代码优先简介 不得不提Entity Framework Code First这个 ...

随机推荐

  1. SOAPUI使用教程-REST服务和WADL

    首先创建一个新的REST项目: 选择文件|新建项目REST从主菜单: 通常情况下,我们可能会只提供一个URI 点击导入消耗. 在新建项目消耗对话框: 点击浏览. 然后,我们可以浏览到该文件: 点击   ...

  2. python基础05 if选择

    摘要:if语句是用来检查一个条件,如果条件为真(true),我们运行一个语句块(称为IF块),否则(else)运行另一个语句块(else块).else语句是可选的 程序1(将文件保存为if.py): ...

  3. 关于这个博客以及C++入门该懂的一些东西

    给三牧中学c++入门的同学们看的博客. 大概是入门一类的?说不定会写点自己的结题报告. 写的不好/写错了别怪我,蒟蒻瑟瑟发抖. 天哪要开始写入门了我好慌那么接下来是编译器连接. (本蒟蒻喜欢用DEV ...

  4. Python 进程间通信

    from multiprocessing import Process,Queue import os,time,random def write(q): print('Process to writ ...

  5. Salesforce学习笔记(一)

    Force平台简介 一.Force平台应用程序的优点1.以数据为中心的应用程序(一个对象就是一个数据库表) 由于该平台以数据库为中心,它让你能够编写以数据为中心的应用程序.以数据为中心的应用程序是基于 ...

  6. String对象方法扩展

    /** *字符串-格式化 */ String.prototype.format = function(){ var args = arguments;//获取函数传递参数数组,以便在replace回调 ...

  7. HTTP协议详解(转)

    转自:http://blog.csdn.net/gueter/archive/2007/03/08/1524447.aspx Author :Jeffrey 引言 HTTP是一个属于应用层的面向对象的 ...

  8. jquery.ajax

    var params = {};//定义一个数组 var USERNAME= $("#USERNAME").val(); params["USERNAME"]= ...

  9. C#_技巧:真伪随机数

    使用 Random 产生随机数.(这是一种伪随机数,需要seed,同一个seed后,采用某种算法产生的数字序列都是一样的) 两种写法 错误 for(int i=0;i<100;i++) {    ...

  10. 通过js实现回到顶部功能

    许多商城网址,当我们滚动到一定高度时,我们会发现一般会出现一个回到顶部的js选项,点击轻松实现回到顶部,交互效果会显得比较人性化,且回到顶部过程中若在滚动滚动条时可以停止滚动,现在让我们来实现吧 我总 ...