EF - linq (whole word )查询

whole word 查询

where'$'+ts.TargetSegment+'$' LIKE '%[^a-z0-9]a[^a-z0-9]%'

charindex 解释

CHARINDEX ( expression1 , expression2 [ , start_location ] )

   Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始在expression2中找expression1的位置。

   CHARINDEX函数返回一个整数,返回的整数是要找的字符串在被找的字符串中的位置。假如CHARINDEX没有找到要找的字符串,那么函数整数“0”。

1 查找左右是空格与自己


LINQ 写法

segmentsProjectTaskSQL.Where(t =>
                           t.ts.TargetSegment == searchTarget
                           || (t.ts.TargetSegment.Contains(" " + searchTarget + " ")
                              || t.ts.TargetSegment.StartsWith(searchTarget + " ")
                              || t.ts.TargetSegment.EndsWith(" " + searchTarget))
                           );

生成的SQL

and (( CAST(charindex(N' '+'a'+' ', ts.TargetSegment) AS int)) > 0 or ts.TargetSegment = 'a')

2 查找左右是符号,空格与自己

charindex不支持通配符,所以使用 patindex

var query = db.Products
    .Where( p => SqlFunctions.PatIndex("%[^a-z0-9]a[^a-z0-9]%", "$"+ts.TargetSegment+"$") > 0  );

生成SQL

and (( CAST(patindex(N'%[^a-z0-9]a[^a-z0-9]%', '$' +ts.TargetSegment+'$') AS int)) > 0 or ts.TargetSegment = 'a')

参考

Linq:SqlFunctions.PatIndex与string.包含字符串比较

posted @ 2022-06-06 11:38  【唐】三三  阅读(109)  评论(0编辑  收藏  举报