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
相关文章
|
19天前
|
SQL NoSQL Java
Java使用sql查询mongodb
通过使用 MongoDB Connector for BI 和 JDBC,开发者可以在 Java 中使用 SQL 语法查询 MongoDB 数据库。这种方法对于熟悉 SQL 的团队非常有帮助,能够快速实现对 MongoDB 数据的操作。同时,也需要注意到这种方法的性能和功能限制,根据具体应用场景进行选择和优化。
64 9
|
1月前
|
SQL 存储 人工智能
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
Vanna 是一个开源的 Python RAG(Retrieval-Augmented Generation)框架,能够基于大型语言模型(LLMs)为数据库生成精确的 SQL 查询。Vanna 支持多种 LLMs、向量数据库和 SQL 数据库,提供高准确性查询,同时确保数据库内容安全私密,不外泄。
148 7
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
|
2月前
|
SQL Java
使用java在未知表字段情况下通过sql查询信息
使用java在未知表字段情况下通过sql查询信息
43 8
|
2月前
|
SQL 安全 PHP
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
72 4
|
2月前
|
SQL 监控 关系型数据库
SQL语句当前及历史信息查询-performance schema的使用
本文介绍了如何使用MySQL的Performance Schema来获取SQL语句的当前和历史执行信息。Performance Schema默认在MySQL 8.0中启用,可以通过查询相关表来获取详细的SQL执行信息,包括当前执行的SQL、历史执行记录和统计汇总信息,从而快速定位和解决性能瓶颈。
|
2月前
|
SQL 存储 缓存
如何优化SQL查询性能?
【10月更文挑战第28天】如何优化SQL查询性能?
197 10
|
2月前
|
SQL 关系型数据库 MySQL
|
2月前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
|
3月前
|
SQL 数据库 开发者
功能发布-自定义SQL查询
本期主要为大家介绍ClkLog九月上线的新功能-自定义SQL查询。
|
3月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录