Entity Framework Core 与 SQL Server 携手,高级查询技巧大揭秘!让你的数据操作更高效!

简介: 【8月更文挑战第31天】Entity Framework Core (EF Core) 是一个强大的对象关系映射(ORM)框架,尤其与 SQL Server 数据库结合使用时,提供了多种高级查询技巧,显著提升数据操作效率。它支持 LINQ 查询,使代码简洁易读;延迟加载与预先加载机制优化了相关实体的加载策略;通过 `FromSqlRaw` 或 `FromSqlInterpolated` 方法支持原始 SQL 查询;可调用存储过程执行复杂任务;利用 `Skip` 和 `Take` 实现分页查询,便于处理大量数据。这些特性共同提升了开发者的生产力和应用程序的性能。

Entity Framework Core(EF Core)是一个强大的对象关系映射(ORM)框架,它与 SQL Server 数据库结合使用时,可以提供许多高级查询技巧,帮助开发者更高效地操作数据。

一、LINQ 查询

EF Core 支持使用 LINQ(Language Integrated Query)进行查询,这使得查询代码更加简洁和可读。例如,要查询所有年龄大于 30 的用户,可以这样写:

using (var context = new MyDbContext())
{
   
    var users = context.Users.Where(u => u.Age > 30).ToList();
}

LINQ 还支持复杂的查询操作,如排序、分组、连接等。例如,要查询每个城市的用户数量,可以这样写:

using (var context = new MyDbContext())
{
   
    var cityUserCounts = context.Users.GroupBy(u => u.City)
                                      .Select(g => new {
    City = g.Key, UserCount = g.Count() })
                                      .ToList();
}

二、延迟加载与预先加载

EF Core 支持延迟加载和预先加载两种加载策略。延迟加载是指在访问相关实体时才实际加载它们,而预先加载则是在查询主实体时同时加载相关实体。

例如,假设我们有一个用户实体和一个订单实体,一个用户可以有多个订单。如果使用延迟加载,当我们访问用户的订单时,EF Core 会自动发出查询来加载订单:

using (var context = new MyDbContext())
{
   
    var user = context.Users.FirstOrDefault();
    if (user!= null)
    {
   
        // 此时不会加载订单,只有在访问 Orders 属性时才会加载
        var orders = user.Orders;
        foreach (var order in orders)
        {
   
            Console.WriteLine(order.Description);
        }
    }
}

如果使用预先加载,可以在查询用户时同时加载他们的订单:

using (var context = new MyDbContext())
{
   
    var user = context.Users.Include(u => u.Orders).FirstOrDefault();
    if (user!= null)
    {
   
        foreach (var order in user.Orders)
        {
   
            Console.WriteLine(order.Description);
        }
    }
}

三、原始 SQL 查询

在某些情况下,可能需要使用原始 SQL 查询来执行复杂的查询或调用数据库特定的功能。EF Core 允许使用FromSqlRawFromSqlInterpolated方法执行原始 SQL 查询。

例如,要查询所有名字以“J”开头的用户,可以这样写:

using (var context = new MyDbContext())
{
   
    var users = context.Users.FromSqlInterpolated($"SELECT * FROM Users WHERE Name LIKE 'J%'").ToList();
}

四、存储过程调用

EF Core 也支持调用存储过程。首先,在数据库中创建存储过程,然后在 EF Core 中可以通过FromSqlRawFromSqlInterpolated方法调用存储过程。

例如,假设我们有一个存储过程GetUsersByAge,用于查询特定年龄范围内的用户。可以这样调用存储过程:

using (var context = new MyDbContext())
{
   
    var minAge = 25;
    var maxAge = 40;
    var users = context.Users.FromSqlInterpolated($"EXEC GetUsersByAge @MinAge={minAge}, @MaxAge={maxAge}").ToList();
}

五、分页查询

在处理大量数据时,分页查询是非常有用的。EF Core 可以通过SkipTake方法实现分页查询。

例如,要查询第二页的数据,每页显示 10 条记录,可以这样写:

using (var context = new MyDbContext())
{
   
    var pageNumber = 2;
    var pageSize = 10;
    var users = context.Users.Skip((pageNumber - 1) * pageSize).Take(pageSize).ToList();
}

总之,Entity Framework Core 与 SQL Server 结合使用时,可以提供许多高级查询技巧,帮助开发者更高效地操作数据。通过使用 LINQ 查询、延迟加载与预先加载、原始 SQL 查询、存储过程调用和分页查询等技巧,可以满足各种复杂的查询需求。

以下是一个完整的示例代码,展示了上述高级查询技巧的使用:

using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Linq;

namespace EfCoreSqlServerAdvancedQueries
{
   
    public class User
    {
   
        public int Id {
    get; set; }
        public string Name {
    get; set; }
        public int Age {
    get; set; }
        public string City {
    get; set; }
        public virtual ICollection<Order> Orders {
    get; set; }
    }

    public class Order
    {
   
        public int Id {
    get; set; }
        public int UserId {
    get; set; }
        public string Description {
    get; set; }
    }

    public class MyDbContext : DbContext
    {
   
        public DbSet<User> Users {
    get; set; }
        public DbSet<Order> Orders {
    get; set; }

        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
   
            optionsBuilder.UseSqlServer("YourConnectionString");
        }
    }

    class Program
    {
   
        static void Main()
        {
   
            using (var context = new MyDbContext())
            {
   
                // LINQ 查询
                var olderUsers = context.Users.Where(u => u.Age > 30).ToList();
                Console.WriteLine("Users older than 30:");
                foreach (var user in olderUsers)
                {
   
                    Console.WriteLine(user.Name);
                }

                // 预先加载
                var usersWithOrders = context.Users.Include(u => u.Orders).ToList();
                Console.WriteLine("Users with orders:");
                foreach (var user in usersWithOrders)
                {
   
                    Console.WriteLine($"User: {user.Name}, Orders:");
                    foreach (var order in user.Orders)
                    {
   
                        Console.WriteLine($"  - {order.Description}");
                    }
                }

                // 原始 SQL 查询
                var jUsers = context.Users.FromSqlInterpolated($"SELECT * FROM Users WHERE Name LIKE 'J%'").ToList();
                Console.WriteLine("Users starting with J:");
                foreach (var user in jUsers)
                {
   
                    Console.WriteLine(user.Name);
                }

                // 分页查询
                var pageNumber = 2;
                var pageSize = 10;
                var paginatedUsers = context.Users.Skip((pageNumber - 1) * pageSize).Take(pageSize).ToList();
                Console.WriteLine($"Page {pageNumber} of users:");
                foreach (var user in paginatedUsers)
                {
   
                    Console.WriteLine(user.Name);
                }
            }

            Console.ReadLine();
        }
    }
}

在这个示例中,我们展示了如何使用 LINQ 查询、预先加载、原始 SQL 查询和分页查询来操作数据。你可以根据自己的需求选择合适的查询技巧来提高开发效率。

相关文章
|
8月前
|
SQL 人工智能 JSON
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
简介:本文整理自阿里云高级技术专家李麟在Flink Forward Asia 2025新加坡站的分享,介绍了Flink 2.1 SQL在实时数据处理与AI融合方面的关键进展,包括AI函数集成、Join优化及未来发展方向,助力构建高效实时AI管道。
1113 43
|
8月前
|
SQL 人工智能 JSON
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
本文整理自阿里云的高级技术专家、Apache Flink PMC 成员李麟老师在 Flink Forward Asia 2025 新加坡[1]站 —— 实时 AI 专场中的分享。将带来关于 Flink 2.1 版本中 SQL 在实时数据处理和 AI 方面进展的话题。
514 0
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
|
7月前
|
SQL 监控 关系型数据库
一键开启百倍加速!RDS DuckDB 黑科技让SQL查询速度最高提升200倍
RDS MySQL DuckDB分析实例结合事务处理与实时分析能力,显著提升SQL查询性能,最高可达200倍,兼容MySQL语法,无需额外学习成本。
|
7月前
|
SQL 存储 关系型数据库
MySQL体系结构详解:一条SQL查询的旅程
本文深入解析MySQL内部架构,从SQL查询的执行流程到性能优化技巧,涵盖连接建立、查询处理、执行阶段及存储引擎工作机制,帮助开发者理解MySQL运行原理并提升数据库性能。
|
9月前
|
SQL
SQL如何只让特定列中只显示一行数据
SQL如何只让特定列中只显示一行数据
|
11月前
|
SQL 数据挖掘 数据库
第三篇:高级 SQL 查询与多表操作
本文深入讲解高级SQL查询技巧,涵盖多表JOIN操作、聚合函数、分组查询、子查询及视图索引等内容。适合已掌握基础SQL的学习者,通过实例解析INNER/LEFT/RIGHT/FULL JOIN用法,以及COUNT/SUM/AVG等聚合函数的应用。同时探讨复杂WHERE条件、子查询嵌套,并介绍视图简化查询与索引优化性能的方法。最后提供实践建议与学习资源,助你提升SQL技能以应对实际数据处理需求。
808 1
|
7月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
8月前
|
SQL XML Java
通过MyBatis的XML配置实现灵活的动态SQL查询
总结而言,通过MyBatis的XML配置实现灵活的动态SQL查询,可以让开发者以声明式的方式构建SQL语句,既保证了SQL操作的灵活性,又简化了代码的复杂度。这种方式可以显著提高数据库操作的效率和代码的可维护性。
497 18
|
6月前
|
SQL 关系型数据库 MySQL
(SQL)SQL语言中的查询语句整理
查询语句在sql中占了挺大一部分篇幅,因为在数据库中使用查询语句的次数远多于更新与删除命令。而查询语句比起其他语句要更加的复杂,可因为sql是数据库不可或缺的一部分,所以即使不懂,也必须得弄懂,以上。
371 0
|
11月前
|
SQL 关系型数据库 MySQL
凌晨2点报警群炸了:一条sql 执行200秒!搞定之后,我总结了一个慢SQL查询、定位分析解决的完整套路
凌晨2点报警群炸了:一条sql 执行200秒!搞定之后,我总结了一个慢SQL查询、定位分析解决的完整套路
凌晨2点报警群炸了:一条sql 执行200秒!搞定之后,我总结了一个慢SQL查询、定位分析解决的完整套路

热门文章

最新文章

下一篇
开通oss服务