У меня есть сущность и ее отображение:
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 для NHibernate? Например, если пользователь ищет kap
, мне нужно, чтобы он совпадал с Kapiolani
, Makapuu
и Lapkap
.