10、Entity Framework Core 3.1入门教程-执行原生SQL
本文章是根据 微软MVP solenovex(杨旭)老师的视频教程编写而来,再加上自己的一些理解。
视频教程地址:https://www.bilibili.com/video/BV1xa4y1v7rR
GitHub源码:https://github.com/hllive/LearnEFCore3.1
无主键的Entity
- .NetCore3.1允许无主键的Entity或Model
- 它们不会被追踪,相当于是只读的
- 映射到没有主键的Table或View
如何在EFCore中使用原生SQL语句或执行存储过程以及视图
首先执行两个SQL脚本,一个视图和一个存储过程
CREATE VIEW ViewPlayerClub
AS
SELECT p.Id[PlayerId],p.Name[PlayerName],c.Name[ClubName],c.City[ClubCity]
FROM Players p INNER JOIN Clubs c ON p.ClubId=c.Id
GO
CREATE PROCEDURE RemoveGamePlayer
@PlayerId UNIQUEIDENTIFIER
AS
BEGIN
SET NOCOUNT ON;
DELETE FROM GamePlayer WHERE PlayerId=@PlayerId
END
GO
根据视图ViewPlayerClub创建一个类
public class PlayerClub
{
public Guid PlayerId { get; set; }
public string PlayerName { get; set; }
public string ClubName { get; set; }
public string ClubCity { get; set; }
}
再把这个类添加到DBContext中
public DbSet<PlayerClub> PlayerClubs { get; set; }
DbSet使用这个没有主键的类是不行的,怎么才能使用无主键的类呢?
可以在OnModelCreating()方法里设置一下
modelBuilder.Entity<PlayerClub>()
.HasNoKey()//设置没有主键
.ToView("ViewPlayerClub");//如果不写这句,当迁移的时候还会创建一个PlayerClub的Table,应该把这个类映射到一个视图上
针对这种没有主键的model查询出来都是无法追踪的
例子
[HttpGet("PlayerClub")]
public IActionResult GetViewPlayerClub()
{
var playerClub = _dbContext.PlayerClubs.Where(px => px.ClubCity.Contains("贵州")).ToList();
return Ok(playerClub);
}
生成的SQL语句
SELECT [v].[ClubCity], [v].[ClubName], [v].[PlayerId], [v].[PlayerName]
FROM [ViewPlayerClub] AS [v]
WHERE CHARINDEX(N'贵州', [v].[ClubCity]) > 0
如果使用_dbContext.PlayerClubs.Find(Guid id)在编译的时候不会出错,但运行肯定会报错,因为Find()里的参数是主键
原生SQL查询
执行原生SQL查询有两种方法
.FromSqlRaw("SELECT *...")直接写SQL语句.FromSqlRawAsync("SELECT *...").FromSqlInterpolated("$SELECT *...WHERE x={var}")SQL语句需要使用参数.FromSqlInterpolatedAsync("$SELECT *...WHERE x={var}")
FromSqlRaw和FromSqlInterpolated是DbSet()的方法,所以只能针对DbSet方法执行,需要在DbSet()后使用FromSqlRaw
使用FromSqlRaw()方法
[HttpGet("SqlTest")]
public IActionResult GetSqlTest1()
{
var leagues = _dbContext.Leagues.FromSqlRaw("SELECT * FROM Leagues").ToList();
return Ok(leagues);
}
生成的SQL语句就是FromSqlRaw()方法里的语句
使用FromSqlInterpolated()方法
[HttpGet("SqlTest1")]
public IActionResult GetSqlTest1([FromQuery] string name)
{
//使用带参数的FromSqlInterpolated
var leagues = _dbContext.Leagues
.FromSqlInterpolated($"SELECT * FROM Leagues WHERE Name LIKE N'%{name}%'")
.ToList();
return Ok(leagues);
}
生成的SQL语句就是FromSqlInterpolated()方法的语句,但是会使用SQL参数作为查询值
exec sp_executesql N'SELECT * FROM Leagues WHERE Name LIKE N''%@p0%''
',N'@p0 nvarchar(4000)',@p0=N'足球'
原生SQL查询的要求
- 必须返回Entity类型的所有属性,一般都是
SELECT * - 字段名和Entity的属性名必须匹配
- 无法包含关联的数据,不能写JOIN语句
- 只能查询已知的Entity,也就是Context中设定好的或间接能追踪到的数据
执行非查询类SQL
Context.Database.ExecuteSqlRaw()Context.Database.ExecuteSqlRawAsync()Context.Database.ExecuteSqlInterpolated()Context.Database.ExecuteSqlInterpolatedAsync()- 无法用于查询
- 只能返回影响的行数
[HttpGet("SqlTest2")]
public IActionResult GetSqlTest2()
{
//使用ExecuteSqlRaw
var count = _dbContext.Database.ExecuteSqlRaw("EXEC [dbo].[RemoveGamePlayer] {0}", new Guid(""));
//使用ExecuteSqlInterpolated
var counts = _dbContext.Database.ExecuteSqlInterpolated($"EXEC [dbo].[RemoveGamePlayer] {new Guid("")}");
return Ok(new { count, counts });
}
生成的SQL语句两个都一样
博客文章可以转载,但不可以声明为原创
10、Entity Framework Core 3.1入门教程-执行原生SQL的更多相关文章
- 1、Entity Framework Core 3.1入门教程-概述和准备工作
本文章是根据 微软MVP solenovex(杨旭)老师的视频教程编写而来,再加上自己的一些理解. 视频教程地址:https://www.bilibili.com/video/BV1xa4y1v7rR ...
- 3、Entity Framework Core 3.1入门教程-设定字段属性
本文章是根据 微软MVP solenovex(杨旭)老师的视频教程编写而来,再加上自己的一些理解. 视频教程地址:https://www.bilibili.com/video/BV1xa4y1v7rR ...
- 2、Entity Framework Core 3.1入门教程-创建数据库和迁移
本文章是根据 微软MVP solenovex(杨旭)老师的视频教程编写而来,再加上自己的一些理解. 视频教程地址:https://www.bilibili.com/video/BV1xa4y1v7rR ...
- ASP.NET Core 入门教程 8、ASP.NET Core + Entity Framework Core 数据访问入门
一.前言 1.本教程主要内容 ASP.NET Core MVC 集成 EF Core 介绍&操作步骤 ASP.NET Core MVC 使用 EF Core + Linq to Entity ...
- ASP.NET Core 入门笔记9,ASP.NET Core + Entity Framework Core 数据访问入门
一.前言 1.本教程主要内容 ASP.NET Core MVC 集成 EF Core 介绍&操作步骤 ASP.NET Core MVC 使用 EF Core + Linq to Entity ...
- Entity Framework Core 2.0 入门简介
不多说废话了, 直接切入正题. EF Core支持情况 EF Core的数据库Providers: 此外还即将支持CosmosDB和 Oracle. EFCore 2.0新的东西: 查询: EF.Fu ...
- Entity Framework Core 2.0 入门
该文章比较基础, 不多说废话了, 直接切入正题. 该文分以下几点: 创建Model和数据库 使用Model与数据库交互 查询和保存关联数据 EF Core支持情况 EF Core的数据库Provide ...
- (摘)Entity Framework Core 2.1带来更好的SQL语句生成方案
微软发布了Entity Framework Core2.1,为EF开发者带来了很多期待已久的特性.EF Core 2.1增加了对SQL GROUP BY的支持,支持延迟加载和数据种子等. EF Cor ...
- entity framework core在独立类库下执行迁移操作
之前学习EFCore的时候,都是在VS创建的默认模板里面进行的,按照官方文档,直接就可以搞定. 今天新项目准备上.Net Core,打算先按照国际惯例,进行分层,数据访问层是用EFCore来做,于是就 ...
随机推荐
- pandas_处理异常值缺失值重复值数据差分
# 处理异常值缺失值重复值数据差分 import pandas as pd import numpy as np import copy # 设置列对齐 pd.set_option("dis ...
- 接口工具Apifox
最近发现一款接口测试工具--apifox,我我们很难将它描述为一款接口管理工具 或 接口自测试工具. 官方给了一个简单的公式,更能说明apifox可以做什么. Apifox = Postman + S ...
- angular2+ 组件间通信
angular2+ 不同于react的redux,vue的vuex,angular2+其实可实现数据状态管理的方法很多,以下方案一般也足够支撑普通业务: 父子组件通信 1.1 父组件向子组件传递信息( ...
- MyBatis-Plus使用(4)-集成SpringBoot
我这里使用的MyBatis-Plus是当前最新的3.2.0版本, 1. 引入需要的jar,基础jar包括: <dependencies> <dependency> <gr ...
- Python面向对象编程扑克牌发牌程序,另含大量Python代码!
1. 题目 编写程序, 4名牌手打牌,计算机随机将52张牌(不含大小鬼)发给4名牌手,在屏幕上显示每位牌手的牌. 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不 ...
- ES6 面向对象笔记
JS面向对象两大编程思想 面向过程 面向对象 面向过程编程POP 面向过程就是分析出问题的需要步骤,然后用函数一步一步的实现,使用的时候一个一个调用就可以了 面向对象编程OOP ...
- JS click延迟解决方案
click延迟解决方案 移动端click事件会有300ms的延迟,原因是移动端屏幕双击会缩放页面 1.禁止缩放功能 浏览器禁用默认双击缩放行为去掉300ms的点击延迟 user-scalabl ...
- 恢复HTML表格笔记
表格 语法: 标记: <table></table>:表示一个表格 属性: ...
- Bytom Dapp 开发笔记(一):架构设计
简介 研究比原链已经一年了,用比原链做了几个dapp,而且最近还做了一个基于他们插件钱包的dapp,总结了一些遇到的坑,还有一些技术细节,接下来我会分成三章,从dapp设计架构上,到深入到源码分析去帮 ...
- CSDN新版Markdown编辑器(Alpha 2.0版)
Markdown编辑器 欢迎使用Markdown编辑器 新的改变 功能快捷键 合理的创建标题,有助于目录的生成 如何改变文本的样式 插入链接与图片 如何插入一段漂亮的代码片 生成一个适合你的列表 创建 ...