深入解析Entity Framework Core中的自定义SQL查询与Raw SQL技巧:从基础到高级应用的全面指南,附带示例代码与最佳实践建议

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 【8月更文挑战第31天】本文详细介绍了如何在 Entity Framework Core (EF Core) 中使用自定义 SQL 查询与 Raw SQL。首先,通过创建基于 EF Core 的项目并配置数据库上下文,定义领域模型。然后,使用 `FromSqlRaw` 和 `FromSqlInterpolated` 方法执行自定义 SQL 查询。此外,还展示了如何使用 Raw SQL 进行数据更新和删除操作。最后,通过结合 LINQ 和 Raw SQL 构建动态 SQL 语句,处理复杂查询场景。本文提供了具体代码示例,帮助读者理解和应用这些技术,提升数据访问层的效率和灵活性。

使用 Entity Framework Core(EF Core)进行数据访问时,虽然其内置的 LINQ 查询功能已经相当强大,但在某些情况下,可能需要直接执行复杂的 SQL 语句来满足特定的查询需求。EF Core 提供了多种方式来执行自定义 SQL 查询,包括使用 Raw SQL。本文将以技术综述的形式,详细介绍如何在 EF Core 中实现自定义 SQL 查询与 Raw SQL,并通过具体的代码示例展示其实现过程。

首先,我们需要创建一个基于 EF Core 的项目。打开 Visual Studio,创建一个新的 .NET Core 控制台应用程序,并选择模板创建项目。接着,添加 EF Core 相关的 NuGet 包,如 Microsoft.EntityFrameworkCore.SqlServerMicrosoft.EntityFrameworkCore.SqlServer.Design

配置数据库上下文

Models 文件夹中,创建一个 BlogContext 类,用于定义数据库上下文。

using Microsoft.EntityFrameworkCore;

namespace YourProjectName.Models
{
   
    public class BlogContext : DbContext
    {
   
        public BlogContext(DbContextOptions<BlogContext> options)
            : base(options)
        {
   
        }

        public DbSet<Blog> Blogs {
    get; set; }
        public DbSet<Post> Posts {
    get; set; }

        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
   
            base.OnModelCreating(modelBuilder);

            // 配置实体关系
            modelBuilder.Entity<Blog>()
                .HasMany(b => b.Posts)
                .WithOne(p => p.Blog)
                .HasForeignKey(p => p.BlogId);
        }
    }
}

定义领域模型

Models 文件夹中,定义两个实体类 BlogPost

namespace YourProjectName.Models
{
   
    public class Blog
    {
   
        public int BlogId {
    get; set; }
        public string Url {
    get; set; }
        public DateTime CreatedAt {
    get; set; }
        public virtual ICollection<Post> Posts {
    get; set; }
    }

    public class Post
    {
   
        public int PostId {
    get; set; }
        public string Title {
    get; set; }
        public string Content {
    get; set; }
        public int BlogId {
    get; set; }
        public virtual Blog Blog {
    get; set; }
    }
}

使用 Raw SQL 查询

在 EF Core 中,可以通过 FromSqlRawFromSqlInterpolated 方法来执行自定义的 SQL 查询。下面将展示如何使用这两种方法来查询数据。

使用 FromSqlRaw

using System;
using System.Linq;
using Microsoft.EntityFrameworkCore;
using YourProjectName.Models;

namespace YourProjectName
{
   
    class Program
    {
   
        static void Main(string[] args)
        {
   
            var options = new DbContextOptionsBuilder<BlogContext>()
                .UseSqlServer(@"Server=(localdb)\mssqllocaldb;Database=EFCoreCustomQueries;Trusted_Connection=True;")
                .Options;

            using (var context = new BlogContext(options))
            {
   
                // 添加一些测试数据
                context.Blogs.AddRange(
                    new Blog {
    Url = "http://example.com/blog1", CreatedAt = DateTime.Parse("2020-01-01"), Posts = new List<Post>
                    {
   
                        new Post {
    Title = "First Post", Content = "Content of the first post." },
                        new Post {
    Title = "Second Post", Content = "Content of the second post." }
                    }},
                    new Blog {
    Url = "http://example.com/blog2", CreatedAt = DateTime.Parse("2021-01-01"), Posts = new List<Post>
                    {
   
                        new Post {
    Title = "Third Post", Content = "Content of the third post." }
                    }}
                );

                context.SaveChanges();

                // 使用 FromSqlRaw 执行自定义 SQL 查询
                var customQueryResult = context.Blogs
                    .FromSqlRaw("SELECT * FROM Blogs WHERE CreatedAt > @0", DateTime.Parse("2020-01-01"))
                    .ToList();

                foreach (var blog in customQueryResult)
                {
   
                    Console.WriteLine($"Blog URL: {blog.Url}");
                }
            }
        }
    }
}

使用 FromSqlInterpolated

FromSqlInterpolated 方法允许使用字符串插值来构建 SQL 语句,同时自动处理参数绑定。

// 在 Main 方法中添加以下代码
var customQueryResultInterpolated = context.Blogs
    .FromSqlInterpolated($@"
        SELECT * 
        FROM Blogs 
        WHERE CreatedAt > {DateTime.Parse("2020-01-01")}")
    .ToList();

foreach (var blog in customQueryResultInterpolated)
{
   
    Console.WriteLine($"Blog URL: {blog.Url}");
}

使用 Raw SQL 更新和删除数据

除了查询外,还可以使用 Raw SQL 来执行更新和删除操作。

更新数据

// 在 Main 方法中添加以下代码
context.Database.ExecuteSqlRaw("UPDATE Blogs SET Url = 'http://newurl.com' WHERE BlogId = 1");
context.SaveChanges();

删除数据

// 在 Main 方法中添加以下代码
context.Database.ExecuteSqlRaw("DELETE FROM Blogs WHERE BlogId = 2");
context.SaveChanges();

复杂查询与动态 SQL

对于更复杂的查询场景,可以结合 LINQ 和 Raw SQL 来构建动态 SQL 语句。

// 在 Main 方法中添加以下代码
var startDate = DateTime.Parse("2020-01-01");
var endDate = DateTime.Parse("2021-01-01");

var complexQuery = context.Blogs
    .FromSqlInterpolated($@"
        SELECT b.*, COUNT(p.PostId) AS PostCount
        FROM Blogs b
        LEFT JOIN Posts p ON b.BlogId = p.BlogId
        WHERE b.CreatedAt BETWEEN {startDate} AND {endDate}
        GROUP BY b.BlogId, b.Url, b.CreatedAt")
    .ToList();

foreach (var blog in complexQuery)
{
   
    Console.WriteLine($"Blog URL: {blog.Url}, Post Count: {blog.PostCount}");
}

总结

通过上述步骤,我们展示了如何在 Entity Framework Core 中使用自定义 SQL 查询与 Raw SQL。从配置数据库上下文到定义领域模型,再到实现和使用 Raw SQL 查询,每个环节都体现了如何利用 EF Core 的强大功能来处理复杂的数据库操作。希望本文提供的示例代码和技术指南能够帮助你在实际项目中更好地应用这些技术,构建出高效且功能丰富的数据访问层。

自定义 SQL 查询和 Raw SQL 不仅能够简化复杂查询的需求,还能提高应用程序的灵活性和可维护性。结合 EF Core 的强大功能,我们可以构建出高度灵活且易于扩展的数据访问层,从而提高生产力并降低维护成本。

相关文章
|
12天前
|
机器学习/深度学习 安全 大数据
揭秘!企业级大模型如何安全高效私有化部署?全面解析最佳实践,助你打造智能业务新引擎!
【10月更文挑战第24天】本文详细探讨了企业级大模型私有化部署的最佳实践,涵盖数据隐私与安全、定制化配置、部署流程、性能优化及安全措施。通过私有化部署,企业能够完全控制数据,确保敏感信息的安全,同时根据自身需求进行优化,提升计算性能和处理效率。示例代码展示了如何利用Python和TensorFlow进行文本分类任务的模型训练。
43 6
|
22天前
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
38 3
|
6天前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
8天前
|
SQL 存储 缓存
如何优化SQL查询性能?
【10月更文挑战第28天】如何优化SQL查询性能?
46 10
|
2天前
|
SQL 关系型数据库 MySQL
|
6天前
|
PHP 开发者 容器
PHP命名空间深度解析与最佳实践####
本文深入探讨了PHP中命名空间(namespace)的机制、应用场景及最佳实践,旨在帮助开发者有效避免命名冲突,提升代码的组织性和可维护性。通过实例讲解,本文将引导您理解如何在实际项目中灵活运用命名空间,以及如何遵循业界公认的最佳实践来优化您的PHP代码结构。 ####
|
4天前
|
PHP 开发者
PHP 7新特性深度解析及其最佳实践
【10月更文挑战第31天】本文将深入探讨PHP 7带来的革新,从性能提升到语法改进,再到错误处理机制的变革。我们将通过实际代码示例,展示如何高效利用这些新特性来编写更加健壮和高效的PHP应用。无论你是PHP新手还是资深开发者,这篇文章都将为你打开一扇窗,让你看到PHP 7的强大之处。
|
16天前
|
SQL 数据库 开发者
功能发布-自定义SQL查询
本期主要为大家介绍ClkLog九月上线的新功能-自定义SQL查询。
|
13天前
|
监控 安全 Serverless
"揭秘D2终端大会热点技术:Serverless架构最佳实践全解析,让你的开发效率翻倍,迈向技术新高峰!"
【10月更文挑战第23天】D2终端大会汇聚了众多前沿技术,其中Serverless架构备受瞩目。它让开发者无需关注服务器管理,专注于业务逻辑,提高开发效率。本文介绍了选择合适平台、设计合理函数架构、优化性能及安全监控的最佳实践,助力开发者充分挖掘Serverless潜力,推动技术发展。
34 1
|
16天前
|
监控 安全 Java
构建高效后端服务:微服务架构深度解析与最佳实践###
【10月更文挑战第19天】 在数字化转型加速的今天,企业对后端服务的响应速度、可扩展性和灵活性提出了更高要求。本文探讨了微服务架构作为解决方案,通过分析传统单体架构面临的挑战,深入剖析微服务的核心优势、关键组件及设计原则。我们将从实际案例入手,揭示成功实施微服务的策略与常见陷阱,为开发者和企业提供可操作的指导建议。本文目的是帮助读者理解如何利用微服务架构提升后端服务的整体效能,实现业务快速迭代与创新。 ###
48 2

推荐镜像

更多
下一篇
无影云桌面