C#中.NET 7.0控制台应用使用LINQtoSQL、LINQtoXML

目录

一、新建控制台应用和数据库连接

二、手动添加System.Data.Linq程序包

三、手动添加System.Data.SqlClient程序包

四、再次操作DataClasses1.dbml

五、示例

1.源码

2.xml文件


默认安装的.NET 7.0控制台应用是不支持使用LINQtoSQL、LINQtoXML的。

默认安装的.NET Framework控制台应用和窗体应用都支持LINQtoSQL、LINQtoXML类的。

.NET Framework的Windows窗体应用、控制台应用,默认安装后或添加LINQtoSQL、LINQtoXML类后都能自动生成完整的支持文件,而.NET 7.0控制台应用和窗体应用,默认安装或添加应用后不能自动生成完整的支持文件。

比照缺少的支持文件,手动添加,就有可能获得.NET 7.0控制台应用、窗体应用支持使用LINQtoSQL、LINQtoXML的解决方案。

本文作者在上一片文章中发布了.NET 7.0窗体应用支持使用LINQtoSQL、LINQtoXML的解决方案。在本文中,作者将公布.NET 7.0控制台应用支持使用LINQtoSQL、LINQtoXML的解决方案。

一、新建控制台应用和数据库连接

VS2022→新建C#控制台应用.NET 7.0→新建数据库连接db_CSharp→添加LINQtoSQL,如建立过该类,接受确认,双击DataClasses1.dbml,拖拽入数据表tb_Employee、tb_Salary,保存,资源管理器里会自动生成一些文件,但不全,打开DataClasses1.designer.cs,会发现一片红警(类似的截图在作者上一篇文章中有,读者也可以亲自测试)→,发现缺少很多支持文件:System.Data.Linq、System.Data.Linq.Mapping(现象:这些using是虚的)。

二、手动添加System.Data.Linq程序包

这个文件让程序支持LINQ,仅仅有它不一定对全部的LINQ有用,但没有它一定不支持LINQ。

通过NuGet下载安装netcore-system.data.linq.7.0.4。具体的操作已经发布在作者的上一篇文章中。

安装这个程序包后,使得我的程序获得支持LINQtoXML类。

三、手动添加System.Data.SqlClient程序包

通过NuGet下载安装 system.data.sqlclient.4.8.5。

安装这个程序包后,使得我的程序获得支持LINQtoSQL类。

四、再次操作DataClasses1.dbml

双击DataClasses1.dbml →删除窗体中曾经添加的数据表tb_Employee、tb_Salary,保存 →重新添加数据表tb_Employee、tb_Salary,保存。→ 再次打开DataClasses1.designer.cs,发现曾经的一片红警,消失了。

至此,在.NET 7.0控制台应用里支持使用LINQtoSQL、LINQtoXML的开发环境搭建完成。

五、示例

在上述的开发环境中,设计一段程序生成一个新的XML文件,这个XML的数据源自数据库db_CSharp的两个数据表:从数据表tb_Employee取前三个记录,每个记录选取ID和Name两个元素,从数据表tb_Salary前一个记录的元素Salary。

1.源码

cs 复制代码
// .NET7.0控制台应用支持LINQtoSQL和LINQtoXML
using System.Data;
using System.Xml.Linq;

namespace _10_2
{
    class Program
    {    
        static void CreateXmlFromDatabase()
        {
            string path = Directory.GetCurrentDirectory() + @"\Createbydb.xml";
            string strCon = "Data Source=DESKTOP-3LV13FS;Integrated Security=True;Database=db_CSharp;";
            DataClasses1DataContext? _Linq;          //声明Linq连接对象并声明成为非null值
            _Linq = new DataClasses1DataContext(strCon);

            XElement root = new("db_CSharp", _Linq.tb_Employee.Select(c => new XElement("tb_Employee",
            new XElement("ID", c.ID),
            new XElement("Name", c.Name),
            new XElement("db_CSharp", _Linq.tb_Salary.Select(p => new XElement("tb_Salary",
            new XElement("Salary", p.Salary))).Take(1)))).Take(3)
            );
            root.Save(path);
        }

        static void Main(string[] args)
        {
            CreateXmlFromDatabase();
        }
    }
}

2.xml文件

XML 复制代码
<db_CSharp>
    <tb_Employee>
        <ID>YGBH0001</ID>
        <Name>小王</Name>
        <db_CSharp>
            <tb_Salary>
                <Salary>1500</Salary>
            </tb_Salary>
            <tb_Salary>
                <Salary>3000</Salary>
            </tb_Salary>
            <tb_Salary>
                <Salary>5000</Salary>
            </tb_Salary>
        </db_CSharp>
    </tb_Employee>
    <tb_Employee>
        <ID>YGBH0002</ID>
        <Name>小李</Name>
        <db_CSharp>
            <tb_Salary>
                <Salary>1500</Salary>
            </tb_Salary>
            <tb_Salary>
                <Salary>3000</Salary>
            </tb_Salary>
            <tb_Salary>
                <Salary>5000</Salary>
            </tb_Salary>
        </db_CSharp>
    </tb_Employee>
    <tb_Employee>
        <ID>YGBH0003</ID>
        <Name>小刘留</Name>
        <db_CSharp>
            <tb_Salary>
                <Salary>1500</Salary>
            </tb_Salary>
            <tb_Salary>
                <Salary>3000</Salary>
            </tb_Salary>
            <tb_Salary>
                <Salary>5000</Salary>
            </tb_Salary>
        </db_CSharp>
    </tb_Employee>
</db_CSharp>

读者看出什么问题来了吗?如何解决,欢迎提供方案。

相关推荐
淀粉肠kk1 分钟前
【C++11】智能指针详解
开发语言·c++
kyriewen1111 分钟前
Next.js部署:从本地跑得欢,到线上飞得稳
开发语言·前端·javascript·科技·react.js·前端框架·ecmascript
AI人工智能+电脑小能手11 分钟前
【大白话说Java面试题】【Java基础篇】第21题:HashMap和Hashtable的区别是什么
java·开发语言·面试·哈希算法·散列表·hash table
不想写代码的星星13 分钟前
COW(Copy-on-Write):开抄开抄,哎嘿,我装的
开发语言·c++
慕容卡卡15 分钟前
Claude 使用神器(web页面)--CloudCLI UI
java·开发语言·前端·人工智能·ui·spring cloud
咬_咬16 分钟前
go语言学习(函数)
开发语言·学习·golang
froginwe1118 分钟前
PHP MySQL Delete 操作指南
开发语言
凯瑟琳.奥古斯特20 分钟前
图论核心考点精讲
开发语言·数据结构·算法·排序算法·哈希算法
charlie11451419125 分钟前
嵌入式Linux驱动开发(8)——内存映射 I/O - 别拿物理地址当指针用
linux·开发语言·驱动开发·c·imx6ull
_日拱一卒25 分钟前
LeetCode:146LRU缓存
java·开发语言