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

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: 【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 查询和分页查询来操作数据。你可以根据自己的需求选择合适的查询技巧来提高开发效率。

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
7天前
|
SQL 监控 关系型数据库
SQL语句当前及历史信息查询-performance schema的使用
本文介绍了如何使用MySQL的Performance Schema来获取SQL语句的当前和历史执行信息。Performance Schema默认在MySQL 8.0中启用,可以通过查询相关表来获取详细的SQL执行信息,包括当前执行的SQL、历史执行记录和统计汇总信息,从而快速定位和解决性能瓶颈。
|
18天前
|
SQL 存储 缓存
如何优化SQL查询性能?
【10月更文挑战第28天】如何优化SQL查询性能?
64 10
|
12天前
|
SQL 关系型数据库 MySQL
|
26天前
|
SQL 数据库 开发者
功能发布-自定义SQL查询
本期主要为大家介绍ClkLog九月上线的新功能-自定义SQL查询。
|
1月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
1月前
|
SQL Java 数据库连接
如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
【10月更文挑战第6天】在代码与逻辑交织的世界中,我从一名数据库新手出发,通过不断探索与实践,最终成为熟练掌握JDBC的开发者。这段旅程充满挑战与惊喜,从建立数据库连接到执行SQL语句,再到理解事务管理和批处理等高级功能,每一步都让我对JDBC有了更深的认识。示例代码展示了如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
88 5
|
1月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
1月前
|
SQL 移动开发 大数据
SQL语句查询连续六天满足条件的记录
在数据库管理和数据分析中,我们经常需要查询符合特定时间范围内连续几天的记录
|
1月前
|
SQL 数据挖掘 关系型数据库
SQL查询次数大于1的记录:高效技巧与方法
在数据库管理中,经常需要统计某些操作的次数,特别是当需要找出哪些记录或值出现的次数超过一定阈值(如大于1次)时
|
1月前
|
SQL 存储 安全
SQL查询数据库:基础概念与操作指南
在数字化时代,数据库已成为信息管理的重要工具之一。作为管理和操作数据库的核心语言,SQL(结构化查询语言)已成为数据管理和查询的关键技能。本文将全面介绍SQL查询数据库的基本概念、语句和操作指南,以帮助初学者快速上手,同时为进阶用户提供有价值的参考。一、数据库与SQL简介数据库是一种存储、管理和检索
42 3