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类的故障全部解决。

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/165289.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux系统下读取当前硬盘的温度

这个其实很简单,借助于smartctl工具(Ubuntu默认安装好了),标红的部分就是当前温度,单位是摄氏度。 sudo smartctl -l scttempsts /dev/sda

NetworkManager 图形化配置 bond

1、在桌面右下角找到网络连接标识,鼠标右击,选择编辑连接,如下图 注意:此次示例使用 ens37 和 ens38 两张网卡组成 bond。在配置 bond 前为了网 络稳定如果子网卡已有网络连接的建议先删除 bond 子网卡的网络连接。 2、单击按钮&a…

Linux/centos上如何配置管理Web服务器?

Linux/centos上如何配置管理Web服务器? 1 Web简单了解2 关于Apache3 如何安装Apache服务器?3.1 Apache服务安装3.2 httpd服务的基本操作 4 如何配置Apache服务器?4.1 关于httpd.conf配置4.2 常用指令 5 简单实例 1 Web简单了解 Web服务器称为…

采集Prestashop独立站

这是一个用Lua编写的爬虫程序,用于采集Prestashop独立站的内容。爬虫程序使用代理信息:proxy_host: jshk.com.cn。 -- 首先,我们需要导入所需的库 local http require(socket.http) local url require(socket.url)-- 然后,我们…

Leetcode—2578.最小和分割【简单】

2023每日刷题&#xff08;二十三&#xff09; Leetcode—2578.最小和分割 实现代码 class Solution { public:int splitNum(int num) {vector<int> a;while(num) {a.push_back(num % 10);num / 10;}int n a.size();sort(a.begin(), a.begin() n);int num1 0;int num…

el-select多选以tag展示时,超过显示长度以...省略号显示,且在一行展示

效果&#xff1a; 代码&#xff1a; <span>系统词典维度&#xff1a;</span><el-selectv-model"dNum"placeholder"请选择"multiplecollapse-tags //设置collapse-tags属性将它们合并为一段文字size"small"style"width:160p…

Netty入门指南之NIO Buffer详解

作者简介&#xff1a;☕️大家好&#xff0c;我是Aomsir&#xff0c;一个爱折腾的开发者&#xff01; 个人主页&#xff1a;Aomsir_Spring5应用专栏,Netty应用专栏,RPC应用专栏-CSDN博客 当前专栏&#xff1a;Netty应用专栏_Aomsir的博客-CSDN博客 文章目录 参考文献前言ByteBu…

MySQL库的库操作指南

1.创建数据库 一般格式&#xff1a;create database (if not exists) database1_name,database2_name...... 特殊形式&#xff1a; create database charset harset_name collate collate_name 解释&#xff1a; 红色字是用户自己设置的名称charset&#xff1a;指定数据…

Jupyter Notebook 内核似乎挂掉了,它很快将自动重启

报错原因&#xff1a; OMP: Error #15: Initializing libiomp5md.dll, but found libiomp5md.dll already initialized. OMP: Hint This means that multiple copies of the OpenMP runtime have been linked into the program. That is dangerous, since it can degrade perfo…

STM32两轮平衡小车原理详解(开源)

一、引言 关于STM32两轮平衡车的设计&#xff0c;我想在读者阅读本文之前应该已经有所了解&#xff0c;所以本文的重点是代码的分享和分析。至于具体的原理&#xff0c;我觉得读者不必阅读长篇大论的文章&#xff0c;只需按照本文分享的代码自己亲手制作一辆平衡车&#xff0c…

OSPF下的MGRE实验

一、实验要求 1、R1-R3-R4构建全连的MGRE环境 2、R1-R5-R6建立hub-spoke的MGRE环境&#xff0c;其中R1为中心 3、R1-R3...R6均存在环回网段模拟用户私网&#xff0c;使用OSPF使全网可达 4、其中R2为ISP路由器&#xff0c;仅配置IP地址 二、实验拓扑图 三、实验配置 1、给各路…

OAuth2.0双令牌

OAuth 2.0是一种基于令牌的身份验证和授权协议&#xff0c;它允许用户授权第三方应用程序访问他们的资源&#xff0c;而不必共享他们的凭据。 在OAuth 2.0中&#xff0c;通常会使用两种类型的令牌&#xff1a;访问令牌和刷新令牌。访问令牌是用于访问资源的令牌&#xff0c;可…