У меня есть сущность и ее отображение:
public class Test
{
public virtual int Id { get; set; }
public virtual string Name { get; set; }
public virtual string Description { get; set; }
}
public class TestMap : EntityMap<Test>
{
public TestMap()
{
Id(x => x.Id);
Map(x => x.Name);
Map(x => x.Description);
}
}
Я пытаюсь запустить запрос на него (чтобы извлечь его из базы данных):
var keyword = "test" // this is coming in from the user
keyword = keyword.ToLower(); // convert it to all lower-case
var results = session.Linq<Test>
.Where(x => x.Name.ToLower().Contains(keyword));
results.Count(); // execute the query
Однако всякий раз, когда я запускаю этот запрос, я получаю следующее исключение:
Index was out of range. Must be non-negative and less than the size of the
collection. Parameter name: index
Я прав, когда я говорю, что в настоящее время Linq для NHibernate не поддерживает ToLower()
? И если да, есть ли альтернатива, которая позволяет мне искать строку в середине другой строки, с которой Linq to NHibernate совместим? Например, если пользователь ищет kap
, мне нужно, чтобы он соответствовал Kapiolani
, Makapuu
и Lapkap
.