数据库中过滤数据与在内存中过滤数据(延迟加载)

简介: var temp = from u in dbContextTable  where u.ID>4  select u;规范的写法其实是:IQueryable temp=from u in dbContextTable  where u.

var temp = from u in dbContextTable
  where u.ID>4
  select u;
规范的写法其实是:
IQueryable<TableName> temp=from u in dbContextTable
  where u.ID>4
  sele ct u;
或者IQueryable temp=from u in dbContextTable
  where u.ID>4
  sele ct u;
(因为IQueryable<TableName>继承IQueryable,所以可以直接用其基类型)

上面的查询语句初始化了IQueryable接口里面的三个参数
1.linq表达式转成Expression类型
2.给Type ElementType赋值,也就是Model的类型
3.给IQueryable Provider赋值,ef provider
当用到IQueryable接口的集合的数据的时候,provider(这里是EFProvider)解析Expresion表达式获取相应的数据。再进行foreach遍历。
Linq to XML则是XML Provider
linq to ***则是*** Provider

在数据库内进行过滤:Where表达式会生成到查询语句中,也就是说Linq to EF查询是在数据库内进行过滤的。可以用数据库监测工具查看EF自动生成的。

sql语句。
例如:
SELECT
    [Extent1].[Id] AS [Id],
    [Extent1].[UserName] AS [UserName],
    [Extent1].[Pwd] AS [Pwd]
    FROM [dbo].[UserSet] AS [Extent1]
    WHERE [Extent1].[Id] > 200

在内存里面过滤:把数据库里面的数据查询出来到内存再过滤,如果数据过多,内存会Boom。
什么情况下使用内存过滤:
List集合(之前学过的经典集合,例如:Array,Dictionary。。。)和

IQueryable接口的不同点。
linq to object
立即将数据库表的数据加载到List中来
var demoList=from u in dbContext.TableName.ToList()
  where u.ID>4
  select u;
例如:
SELECT
    [Extent1].[Id] AS [Id],
    [Extent1].[UserName] AS [UserName],
    [Extent1].[Pwd] AS [Pwd]
    FROM [dbo].[UserSet] AS [Extent1]
是没有where过滤语句的
还可借助VS的调试工具设置断点看看

区别:
Model First

目录
相关文章
|
25天前
|
存储 Oracle 关系型数据库
Dataphin常见问题之想要周期执行任务如何解决
Dataphin是阿里云提供的一站式数据处理服务,旨在帮助企业构建一体化的智能数据处理平台。Dataphin整合了数据建模、数据处理、数据开发、数据服务等多个功能,支持企业更高效地进行数据治理和分析。
|
2天前
|
存储 关系型数据库 MySQL
如何处理爬取到的数据,例如存储到数据库或文件中?
处理爬取的数据,可存储为txt、csv(适合表格数据)或json(适合结构化数据)文件。若需存储大量数据并执行复杂查询,可选择关系型(如MySQL)或非关系型(如MongoDB)数据库。以MySQL为例,需安装数据库和Python的pymysql库,创建数据库和表,然后编写Python代码进行数据操作。选择存储方式应考虑数据类型、数量及后续处理需求。
7 1
|
3天前
|
SQL 关系型数据库 MySQL
关系型数据库插入数据的语句
使用SQL的`INSERT INTO`语句向关系型数据库的`students`表插入数据。例如,插入一个`id`为1,`name`为&#39;张三&#39;,`age`为20的记录:`INSERT INTO students (id, name, age) VALUES (1, &#39;张三&#39;, 20)。如果`id`自增,则可简化为`INSERT INTO students (name, age) VALUES (&#39;张三&#39;, 20)`。
5 2
|
3天前
|
SQL 存储 Oracle
关系型数据库查询数据的语句
本文介绍了关系型数据库中的基本SQL查询语句,包括选择所有或特定列、带条件查询、排序、分组、过滤分组、表连接、限制记录数及子查询。SQL还支持窗口函数、存储过程等高级功能,是高效管理数据库的关键。建议深入学习SQL及相应数据库系统文档。
6 2
|
9天前
|
人工智能 Cloud Native 算法
数据之势丨AI时代,云原生数据库的最新发展趋势与进展
AI与云数据库的深度结合是数据库发展的必然趋势,基于AI能力的加持,云数据库未来可以实现更快速的查询和决策,帮助企业更好地利用海量数据进行业务创新和决策优化。
数据之势丨AI时代,云原生数据库的最新发展趋势与进展
|
11天前
|
存储 C语言
数据在内存中的存储2
数据在内存中的存储2
|
11天前
|
存储 编译器
数据在内存中的存储1
数据在内存中的存储
|
21天前
|
存储 编译器 程序员
【C语言】整形数据和浮点型数据在内存中的存储
【C语言】整形数据和浮点型数据在内存中的存储
13 0
|
23天前
|
监控 关系型数据库 数据库
OceanBase数据库常见问题之增加内存依旧报内存不足如何解决
OceanBase 是一款由阿里巴巴集团研发的企业级分布式关系型数据库,它具有高可用、高性能、可水平扩展等特点。以下是OceanBase 数据库使用过程中可能遇到的一些常见问题及其解答的汇总,以帮助用户更好地理解和使用这款数据库产品。
|
16天前
|
SQL 数据可视化 关系型数据库
轻松入门MySQL:深入探究MySQL的ER模型,数据库设计的利器与挑战(22)
轻松入门MySQL:深入探究MySQL的ER模型,数据库设计的利器与挑战(22)