C#在.NET Windows窗体应用中使用LINQtoSQL

目录

一、新建Windows窗体应用并添加LINQtoSQL类

二、错误信息CS0234

三、添加扩展包让Windows窗体应用支持LINQtoSQL类


默认安装的背景下,新建的Windows窗体应用是不支持LINQtoSQL类的。现象是资源管理器里的依赖项中默认的安装不能自动生成支持system.data.linq和system.data.linq.mapping之类的文件。导致DataClasses1.designer.cs文件里一片红色警告。【本文的作者在其写的其他文章里已经有所涉及】

作者经过摸索、尝试,终于在.NET7.0的 Windows窗体应用中通过在NuGet管理器向新建的应用程序中添加扩展安装包的方法,手动解决了项目资源管理器中依赖项不能自动生成的类库的支持文件,从而让.NET7.0的 Windows窗体应用也能像Windows窗体应用(.NET Framework)那样正常使用LINQtoSQL类。

一、新建Windows窗体应用并添加LINQtoSQL类

这一步的详细步骤在本文作者的其他文章中已经有所涉及,在此不再详述,仅把重要的环节凝练如下:

  • 新建Windows窗体应用,.NET7.0;
  • 新建数据库连接:工具→连接数到据库,在左侧生成服务器资源管理器,然后新建数据库连接,已经建立数据库的,省略此步骤;
  • 新增LINQtoSQL类:右侧,资源管理器,新建LINQtoSQL类。已经建立过得,接受并确认;
  • 向dbml文件中添加数据库:双击DataClasses1.dbml,并从左侧数据库列表中拖拽数据表到向展示的窗口中,保存。
  • 打开自动生成的dbml下的设计器文件:双击DataClasses1.designer.cs,发现很多using光芒暗淡,程序文件很多类名称一片红警(没有第4步,现象也是一片红警,两者的差别是红警的多少)。

二、错误信息CS0234

观看后发现2个命名空间被支持,显示错误信息CS0234 命名空间"System.Data"中不存在类型或命名空间名"Linq"(是否缺少程序集引用?) 。

using System.Data.Linq ;

using System.Data.Linq.Mapping;

尝试解决问题的办法:如果能手动添加支持命名空间的文件,是否能解决遭遇的问题呢?

三、添加扩展包让Windows窗体应用支持LINQtoSQL类

操作流程:鼠标选中资源管理器、依赖项,右侧→管理NuGet程序包,点击→浏览、搜索"system.data.linq",发现没有微软提供的程序包,最接近解决方案的是"netcore-System.Data.Linq 7.0.4"程序包→下载安装→安装结束后,发现不支持的完毕后红警消失,除了"错误 Failed to add reference dll. WinFormsApp2 C:\Users\YCZN_MT\Desktop\测试1\WinFormsApp2\WinFormsApp2\DataClasses1.dbml "之外→删除此前在DataClasses1.dbml中拖拽来的数据库,保存一下,然后再把这个文件重新拖拽回来,再次保存一下。→这个红警也消失了。

至此,所有导致默认、新建的Windows窗体应用不支持LINQtoSQL类的故障全部解决。

相关推荐
寻星探路8 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
lly2024069 小时前
Bootstrap 警告框
开发语言
2601_9491465310 小时前
C语言语音通知接口接入教程:如何使用C语言直接调用语音预警API
c语言·开发语言
曹牧10 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
KYGALYX10 小时前
服务异步通信
开发语言·后端·微服务·ruby
zmzb010310 小时前
C++课后习题训练记录Day98
开发语言·c++
懒人咖11 小时前
缺料分析时携带用料清单的二开字段
c#·金蝶云星空
猫头虎11 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
YUJIANYUE11 小时前
PHP纹路验证码
开发语言·php
仟濹11 小时前
【Java基础】多态 | 打卡day2
java·开发语言