实体框架查询中string.Trim()的行为

dar*_*ect 3 c# sql-server string entity-framework trim

我正在尝试将名称列表复制到SQL Server表中,我为其设置了Entity Framework项目.

名称列表具有重复值,并且其中几个在其末尾具有空格.我希望只插入表中尚未存在的名称,以及从它们的末尾修剪空格.看起来相当简单吧?

我的解决方案是:

if (!context.Names.Any(n => n.Value == nameToCopy.Trim())
  context.Names.Add(nameToCopy.Trim())
Run Code Online (Sandbox Code Playgroud)

NB.这不是我的确切代码,只是一个例子,所以不需要提到我正在修剪两次!

令我惊讶的是,上述方法并不像我预期的那样有效.我发现,同时剖析了上述说法,认为if (!context.Names.Any(n => n.Value == nameToCopy.Trim())实际上并没有查询nameToCopy的修剪版本-几个查询名字对他们的这些末端空间.

但是,如果我执行以下操作,则按预期工作:

string trimmedName = nameToCopy.Trim()
if (!context.Names.Any(n => n.Value == trimmedName)
      context.Names.Add(trimmedName)
Run Code Online (Sandbox Code Playgroud)

任何人都可以解释为什么第一个解决方案不在数据库查询中使用剪裁版本的字符串?

谢谢

小智 7

总体结果应该是相同的.你是如何剖析的?

!context.Names.Any(n => n.Value == nameToCopy.Trim())
Run Code Online (Sandbox Code Playgroud)

上面,Linq to Entities .Trim()转换为TSQL RTRIM(LTRIM()),字符串var以其原始状态发送到SQL Server,并作为查询的一部分进行修剪.

string trimmedName = nameToCopy.Trim()
if (!context.Names.Any(n => n.Value == trimmedName)
Run Code Online (Sandbox Code Playgroud)

虽然如上所述,这.Trim()是正常的,System.String.Trim()并且在发送到SQL Server之前修剪字符串var.