C#中.NET 7.0不再支持ADO.NET,.NET Framwork依旧支持

2023-11-10 18:44

本文主要是介绍C#中.NET 7.0不再支持ADO.NET,.NET Framwork依旧支持,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、.NET 7.0框架下任何应用不再支持ADO.NET

二、.NET Framwork框架下Windows窗体应用支持ADO.NET 

三、.NET 7.0不支持ADO.NET的真正原因


        经过一阵折腾,终于可以确证C#中.NET框架不再支持用户通过ADO.NET的实体框架模型访问数据库,无论是.NET 7.0的控制台应用还是Windows窗体应用都不再支持ADO.NET。或者说,除了.NET Framwork之外的控制台应用还是Windows应用都不再支持ADO.NET。

一、.NET 7.0框架下任何应用不再支持ADO.NET

        .NET 7.0框架下控制台应用不再支持ADO.NET访问数据库。

        .NET 7.0框架下控制台Windows窗体应用不再支持ADO.NET访问数据库。

         现象:“项目的目标框架不包含实体框架运行时程序集。请查春项目属性页中的目标框架信息。”即使通过NuGet 新增安装了如截图内的程序包,这种现象仍然存在。

 

 

 

二、.NET Framwork框架下Windows窗体应用支持ADO.NET 

        .NET Framwork 4.8框架下控制台Windows窗体应用支持ADO.NET访问数据库。并且,也不需要NuGet安装那些程序包。

 

        数据库已经在SSMS中成功连接,连接方法在作者此前的文章中有所涉及,不再这里重复。   

        示例程序生成效果在作者此前的文章中有所涉及,不再这里重复。 

三、.NET 7.0不支持ADO.NET的真正原因

        事实上,自.NET 5.0(这是.NET的第一个版本)诞生之日起,就从来没有支持过ADO.NET。经过查阅,微软关于ADO.NET是这样说的:“ADO.NET 是一组向 .NET Framework 程序员公开数据访问服务的类。”参考文献:

       ADO.NET | Microsoft Learn  https://learn.microsoft.com/zh-cn/dotnet/framework/data/adonet/

        所以,希望在.NET上通过ADO.NET实体模型框架,这个简单易用的途经访问数据库的网友,不要再满世界地寻找解决方案了,因为根本就不存在。

        .NET虽然不支持通过ADO.NET访问数据库,但其仍然支持使用EF,只是需要用户自己编写程序,建立模型,并通过建立的模型访问数据库。比如:.NET 7.0虽然不支持ADO.NET但是却支持EF6.0、EF5.0。关于在.NET 7.0框架下的控制台应用或窗体应用中,自己编写框架模型并通过模型访问数据库的方法,请留意作者的后续文章。

 

 

这篇关于C#中.NET 7.0不再支持ADO.NET,.NET Framwork依旧支持的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/384573

相关文章

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

2、PF-Net点云补全

2、PF-Net 点云补全 PF-Net论文链接:PF-Net PF-Net (Point Fractal Network for 3D Point Cloud Completion)是一种专门为三维点云补全设计的深度学习模型。点云补全实际上和图片补全是一个逻辑,都是采用GAN模型的思想来进行补全,在图片补全中,将部分像素点删除并且标记,然后卷积特征提取预测、判别器判别,来训练模型,生成的像

负债不再是障碍?银行信贷“白名单“揭秘

谈及银行信贷产品,常闻有言称存在无需考量负债与查询记录之奇品,此等说法十有八九为中介诱人上钩之辞。轻信之下,恐将步入连环陷阱。除非个人资质出类拔萃,如就职于国央企或事业单位,工龄逾年,五险一金完备,还款能力卓越,或能偶遇线下产品对查询记录稍显宽容,然亦非全然无视。宣称全然不顾者,纯属无稽之谈。 银行非慈善机构,不轻易于困境中援手,更偏爱锦上添花之举。若无坚实资质,即便求助于银行亦难获青睐。反

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat

C# 防止按钮botton重复“点击”的方法

在使用C#的按钮控件的时候,经常我们想如果出现了多次点击的时候只让其在执行的时候只响应一次。这个时候很多人可能会想到使用Enable=false, 但是实际情况是还是会被多次触发,因为C#采用的是消息队列机制,这个时候我们只需要在Enable = true 之前加一句 Application.DoEvents();就能达到防止重复点击的问题。 private void btnGenerateSh