Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

'string' does not contain a definition for 'Contains'

I have a statement like so:

var vals =
    from StandAloneUserPayment saup in _Session.Query<StandAloneUserPayment>()
        .Fetch(x => x.RecurringPayments)
    where
        saup.User.UserId == userId
        && searchString.Contains(saup.FriendlyName, StringComparer.InvariantCultureIgnoreCase)
    select
        saup;

This seems to be exactly what I'm supposed to do, but I get the whole line with the Contains method underlined with the following message:

string does not contain a definition for Contains and the best extension method overload System.Linq.ParallelEnumerable.Contains<TSource>(System.Linq.ParallelQuery<TSource>, TSource, System.Collections.Generic.IEqualityComparer<TSource>) has some invalid arguments

What am I doing wrong?

like image 994
Jeremy Holovacs Avatar asked Sep 10 '12 00:09

Jeremy Holovacs


2 Answers

Try IndexOf:

searchString.IndexOf(saup.FriendlyName,
                     StringComparison.InvariantCultureIgnoreCase) != -1

The reason it doesn't work is because the Contains extension method that accepts an IEqualityComparer<TSource> is operating on a String, which implements IEnumerable<char>, not IEnumerable<string>, so a string and an IEqualityComparer<string> can't be passed to it.

like image 143
Ry- Avatar answered Oct 06 '22 00:10

Ry-


Even if there is a Contains(source, item, comparer) method, you can't* use that with NHibernate, as comparers are code, not expression trees that NH can translate.

*: that is, unless you write a LINQ provider extension that special-cases generation for your comparer, but that's not the case.

like image 29
Diego Mijelshon Avatar answered Oct 05 '22 23:10

Diego Mijelshon