架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1276|回复: 0

[资料] EF SQL 语句自动生成 IS NULL 或者 IS NOT NULL

[复制链接]
发表于 2023-6-21 22:42:18 | 显示全部楼层 |阅读模式
需求:在 EF 使用 linq to sql 或者 lambda 表达式对数据库查询的时候,EF 生成的 SQL 语句会帮我们增加一些 IS NULL 或者 IS NOT NULL 的条件。

示例一:

它会生成如下 SQL 语句:

SELECT
    [Extent2].[UserStatus] AS [UserStatus],
    [Extent1].[Id] AS [Id]
    FROM  [dbo].[EmailInfo] AS [Extent1]
    INNER JOIN [dbo].[Account] AS [Extent2] ON ([Extent1].[Address] = [Extent2].[Email]) OR (([Extent1].[Address] IS NULL) AND ([Extent2].[Email] IS NULL))

QQ截图20230621215930.jpg

示例二:

它会生成如下 SQL 语句:

SELECT
    [Extent1].[Id] AS [Id],
    [Extent1].[Name] AS [Name],
    [Extent1].[ParentId] AS [ParentId],
    [Extent1].[Position] AS [Position],
    [Extent1].[_CreateTime] AS [_CreateTime],
    [Extent1].[_UpdateTime] AS [_UpdateTime]
    FROM [dbo].[Classification] AS [Extent1]
    WHERE ([Extent1].[Name] IN (N'Android', N'Solaris')) AND ([Extent1].[Name] IS NOT NULL)

QQ截图20230621220327.jpg

如果想避免 EF 生成这些额外的 NULL 条件,可以参考如下。

配置 DbContextConfiguration.UseDatabaseNullSemantics 属性

获取或设置一个值,该值指示当比较两个操作数,而它们都可能为 null 时,是否展示数据库 null 语义。 默认值为 false。

代码如下:


例如:
如果 UseDatabaseNullSemantics 为 true,则 (operand1 == operand2) 将转换为 (operand1 = operand2);
如果 UseDatabaseNullSemantics 为 false,则将转换为 (((operand1 = operand2) AND (NOT (operand1 IS NULL OR operand2 IS NULL))) OR ((operand1 IS NULL) AND (operand2 IS NULL)))。

文档(文档介绍有错误):https://learn.microsoft.com/zh-cn/dotnet/api/system.data.entity.infrastructure.dbcontextconfiguration.usedatabasenullsemantics?view=entity-framework-6.2.0

字段添加 [Required] 特性

EF 在对象属性中添加 [Required] 特性后,其实就是不允许该属性(字段)在数据库中为 NULL 值,执行迁移命令后将该字段不允许为 NULL,既然不允许字段在数据库为 NULL 值,所以 EF 在对该字段生成的 SQL 语句中自然不会生成一些 NULL 检查。

参考:https://learn.microsoft.com/zh-cn/dotnet/api/system.componentmodel.dataannotations.requiredattribute?view=net-7.0






上一篇:ASP.NET Core(二十一)配置选项 AddOptions 和 Configure 区别
下一篇:Web 开发之 ajax-hook 拦截所有 XMLHttpRequest 请求
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-29 00:16

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表