分类 .NET 下的文章

EntityFramework Core查询数据基本本质

【导读】在EntityFramework Core中、当查询出数据后,是如何将数据映射给实体的呢?本节我们预先做个基本探讨,后续给出其底层原理本质

前不久,我们在探索性能时,给出利用反射达到性能瓶颈时的方案即使用委托,如下:

阅读剩余部分

ADO.NET常用对象有哪些(一共5个对象)

Connection :主要是开启程序和数据库之间的连接。没有利用连接对象将数据库打开,是无法从数据 库中取得数据的。Close 和 Dispose 的区别, Close 以后还可以 Open , Dispose 以后则不能再用。

Command :主要可以用来对数据库发出一些指令,例如可以对数据库下达查询、新增、修改、删除数据等指令,以及调用存在数据库中的存储过程等。这个对象是架构在 Connection 对象上。也就是Command 对象是通过在 Connection 对象连接到数据源。

DataAdapter :主要是在数据源以及 DataSet 之间执行数据传输的工作,它可以透过 Command 对象下 达命令后,并将取得的数据放入DataSet 对象中。这个对象是架构在 Command 对象上,并提供了许多 配合DataSet 使用的功能。

DataSet :这个对象可以视为一个暂存区( Cache ),可以把从数据库中所查询到的数据保留起来甚至可以将整个数据库显示出来,DataSet 是放在内存中的。DataSet 的能力不只是可以储存多个 Table 而已,还可以透过DataAdapter 对象取得一些例如主键等的数据表结构,并可以记录数据表间的关联。DataSet 对象可以说是 ADO.NET 中重量级的对象,这个对象架构在 DataAdapter 对象上,本身不具备和 数据源沟通的能力;也就是说我们是将DataAdapter 对象当做 DataSet 对象以及数据源间传输数据的桥 梁。DataSet 包含若干 DataTable 、 DataTableTable 包含若干 DataRow 。

DataReader :当我们只需要循序的读取数据而不需要其它操作时,可以使用 DataReader 对象。DataReader 对象只是一次一次向下循序的读取数据源中的数据,这些数据是存在数据库服务器中的,而 不是一次性加载到程序的内存中的,只能(通过游标)读取当前行的数据,而且这些数据是只读的,并不允许作其它的操作。因为DataReader 在读取数据的时候限制了每次只读取一条,而且只能只读,所以使用起来不但节省资源而且效率很好。使用DataReader 对象除了效率较好之外,因为不用把数据全 部传回,故可以降低网络的负载。

阅读剩余部分

【WPF】Invoke与BeginInvoke的区别

概述

在WPF多线程编程中,经常要在工作线程中更新界面显示,Invoke和BeginInvoke即是为了解决此类问题。在WPF多线程编程模型中,通过Dispatcher调度程序,来管理UI工作项队列,并拥有应用程序主线程,在大多数WPF应用程序中,只存在一个用户界面线程和一个调度器。

阅读剩余部分

如何分析.NET Core HttpClient请求异常(二)

【导读】上一篇我们讨论了针对项目上异常信息的具体分析而给出对应解决方案,本篇仅是我个人对相关异常信息了解过后的进一步学习和思考,希望对后续遇到此异常信息的同学们给予思路扩展

下面我们结合如下两个异常信息进行大致排查分析,到底什么时候会抛出这两个异常信息呢?

阅读剩余部分

.NET 在Docker中访问MSSQL报错

不知道你有没有在.NET Core/.NET 5的Docker访问MS SQL Server数据库,如果有,那么很有可能会遇到这个错误。

1 SSL版本错误

最近在公司用.NET 5重构部分业务服务,由于之前老系统使用了MS SQL Server数据库,因此本次重构也决定继续使用。但是,在将.NET 5应用部署到Docker中通过Swagger测试时,却报了以下一个错误:

阅读剩余部分