查找包含至少一个字符串单词的记录

时间:2019-03-08 14:54:41

标签: c# entity-framework linq

我有医生桌

Doctors:
------------
ID
FullName

用户插入了一个字符串,该字符串可以包含许多单词,例如:“ Leon Simmons”,我希望获得名称中带有“ Leon”或“ Simmons”的所有医生。 问题是我不知道用户将插入多少个单词。 我如何用linq做这样的事情?

3 个答案:

答案 0 :(得分:1)

您可以使用SqlMethods.Like()。

用法示例:

var results =
        from d in doctors
        where SqlMethods.Like(u.FullName, "%Leon Simmons%")
        select d;

答案 1 :(得分:1)

使用linq方法语法的一种可能的解决方案:

    dbContext.Doctors
     .Where(d => d.FullName.Contains("Leon") || d.FullName.Contains("Simmons"))
     .Count();

答案 2 :(得分:1)

尝试:

IQueryable<Doctor> doctorQuery = dbContext.Doctors;
foreach(var word in searchWords)
    doctorQuery = doctorQuery.Where(x => x.FullName.ToLower().Contains(word.ToLower());
return await doctorQuery.ToListAsync();