EntityFramework数据持久化 Linq语法应用

Linq基础语法

LINQ概述

LINQ(Language Integrated Query,语言集成查询)提供了一种跨数据源和数据格式查询的统一模型。

LINQ的组成:

  1. LINQ To Objects:查询集合对象
  2. LINQ enabled ADO.NET:查询数据库
     LINQ To DataSet
     LINQ To SQL
     LINQ To Entities -> EntityFramework
  3. LINQ To XML:查询XML文档

LINQ的语法:
from [type] id in source
[join [type] id in source on expr equals expr [into subGroup]]
[from [type] id in source | let id = expr | where condition]
[orderby ordering,ordering,ordering…]
select expr | group expr by key
[into id query]
注意:只有实现了IEnumerable接口的数据源,才能执行相关的LINQ操作

LINQ方法语法基础
1、方法语法的是通过扩展方法和Lambda表达式来创建查询。
查询语法和方法语法在语义上是相同的,但是大多数情况下发现查询语法更简单且更易于阅读;并且某些查询必须表示为方法调用(比如聚合操作)。

看上述概念大家可能有点不懂什么意思,下面我们用两个简单的案例来进行分析。

首先我们先来三个常用扩展方法, Where(筛选操作)、OrderBy(排序操作)、Select(投影操作)

StubentIfo类

//StubentIfo类
class StubentIfo
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string Sex  { get; set; }
        public int Age { get; set; }
        public string Address { get; set; }
        public string Phone { get; set; }
        public string Email { get; set; }
    }

初始化数据

//初始化数据
            List<StubentIfo> list = new List<StubentIfo>();
            list.Add(new StubentIfo{Id = 1,Name="张三", Sex="男", Age=38, Address="唐山", Email="111", Phone="165412164321" });
            list.Add(new StubentIfo{Id = 2, Name = "张4", Sex = "女", Age = 17, Address = "唐山", Email = "111", Phone = "7355165123431" });
            list.Add(new StubentIfo{ Id = 3, Name = "张5", Sex = "女", Age = 18, Address = "唐山", Email = "111", Phone = "165412164321"});
            list.Add(new StubentIfo{ Id = 4, Name = "张6", Sex = "男", Age = 88,  Address = "唐山", Email = "111", Phone = "564354631521" });
            list.Add(new StubentIfo{ Id = 5, Name = "张7", Sex = "男", Age = 48, Address = "唐山", Email = "111", Phone = "87123412035" });

案例的数据在已经创建好了,下面我们来进行我们的第一个小练习。

例1

在以上数据中筛选出女性用户、并按用户的年龄进行排序。

var lianxi2 = from x in list //数据源
             where x.Sex == "女" //判断条件
             orderby x.Age descending //排序
             select x; 
             //foreach 循环lianxi2,输出结果
foreach (var item in lianxi2)
{
     Console.WriteLine($"编号:{item.Id} 姓名:{item.Name} 性别:{item.Sex} 年龄:{item.Age} 地址:{item.Address} 邮箱:{item.Email} 电话:{item.Phone} ");
}

展示
在这里插入图片描述

例2

查询最高的文综成绩,并将文科学生按照文综成绩降序排列输出

Student类和Score类

 	class Student
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public bool Arts { get; set; }//是否是文科
        public Score Scores { get; set; }//成绩类
    }
    /// <summary>
    /// 成绩
    /// </summary>

     class Score
    {
        public int Chinese { get; set; }
        public int Maths { get; set; }
        public int EngLish { get; set; }
        public int Comprehensive { get; set; } //总成绩

    }

数据添加

static List<Student> students = new List<Student>()
        {
            new Student{Id=1,Name="张1",Arts=false, Scores=new Score{Chinese=127,Maths=145,EngLish=122,Comprehensive=289}},
            new Student{Id=2,Name="张2",Arts=true, Scores=new Score{Chinese=103,Maths=145,EngLish=122,Comprehensive=250}},
            new Student{Id=3,Name="张3",Arts=true, Scores=new Score{Chinese=136,Maths=102,EngLish=122,Comprehensive=189}},
            new Student{Id=4,Name="张4",Arts=true, Scores=new Score{Chinese=126,Maths=145,EngLish=140,Comprehensive=238}},
        };

查询语句

			var data = students.Where(s => s.Arts == true).Max(s=>s.Scores.Comprehensive);
            var data1 = students.Where(s => s.Arts == true).OrderByDescending(s => s.Scores.Comprehensive);
            Console.WriteLine("最高的文综成绩:"+data);
            Console.WriteLine("按照文综成绩降序排列如下:");
            Console.WriteLine("编号\t姓名\t语文\t数学\t英语\t综合");
            foreach (var item in data1)
            {
                Console.WriteLine($"{item.Id}\t{item.Name}\t{item.Scores.Chinese}\t{item.Scores.Maths}\t{item.Scores.EngLish}\t{item.Scores.Comprehensive}");
            }

结果展示
在这里插入图片描述
从上述案例可以看出Linq查询的两种方式基础代码不多,且非常好用,可以在开发是按自己的需求来进行选择。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
Entity Framework 可以实现多数据上传,可以通过以下步骤实现: 1. 创建一个包含所有数据上传的实体类。 2. 实现一个上传数据的方法,使用 Entity Framework 进行数据保存。 3. 在上传数据的方法中,使用事务来确保数据的完整性。 4. 在上传数据的方法中,使用 DbContext 类的实例来操作数据库。 5. 在上传数据的方法中,使用 DbSet 类的实例来操作特定的实体。 6. 在上传数据的方法中,使用 LINQ 查询语言来操作数据。 例如,以下代码展示了如何在 Entity Framework 中实现多数据上传: ``` public void UploadData(List<MyEntity> entities) { using (var context = new MyDbContext()) { using (var transaction = context.Database.BeginTransaction()) { try { foreach (var entity in entities) { context.MyEntities.Add(entity); } context.SaveChanges(); transaction.Commit(); } catch (Exception ex) { transaction.Rollback(); throw ex; } } } } ``` 在这个示例中,我们创建了一个名为 MyEntity 的实体类,并实现了一个 UploadData 方法,该方法接受一个 MyEntity 类型的列表作为参数。在方法中,我们使用 Entity Framework 的 DbContext 类的实例来打开数据库连接,并使用 MyDbContext 类来操作数据库。我们还使用事务来确保数据的完整性,如果在上传数据的过程中发生任何错误,我们将回滚事务。最后,我们使用 SaveChanges() 方法来保存所有更改,并使用 Commit() 方法提交事务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值