Я пытаюсь запросить Posts
на основе списка Tags
:
public class Post
{
public int? Id {get;set;}
public string Name {get;set;}
public virtual ICollection<Tag> Tags {get;set;}
}
public class Tag
{
public int? Id {get;set;}
public string Name {get;set;}
public vritual ICollection<Post> Posts {get;set;}
}
Теперь я хочу возвращать сообщения на основе списка тегов: IList<Tag> searchTags = ParseTagsFromSearchString("tag1,tag2,tag3"); // this function checks the tags in the database, so all the primary keys are available in the list
Если сообщение содержит один или несколько тегов, которые также существуют в searchTags
, оно должно быть включено в результат.Я пробовал следующее:
var q = from s in Context.Registrations
where s.Tags.Intersect(tagList)
select s;
Ошибка: Cannot implicitly convert type 'System.Collections.Generic.IEnumerable<Models.Tag>' to 'bool'
var q = from s in Context.Registrations
where s.Tags.Any(t => tagList.Any(t2 => t.Id.Value == t2.Id.Value))
select s;
Ошибка выполнения: NotSupportedException: Unable to create a constant value of type 'Models.Tag'. Only primitive types ('such as Int32, String, and Guid') are supported in this context.
Есть идеи?
- обновление 4 января.Ответы указывают на правильное решение, но в моем коде у меня все еще есть исключение NotSupportedException.Возможно ли, что обнуляемое целое число вызывает это, так как это не примитивный тип?