Subsonic 3, SimpleRepository, SQL Server: How to find rows with a null field?

Posted by desautelsj on Stack Overflow See other posts from Stack Overflow or by desautelsj
Published on 2009-08-08T21:27:17Z Indexed on 2010/04/02 2:33 UTC
Read the original article Hit count: 436

How ca I use Subsonic's Find<T> method to search for rows with a field containing the "null" value. For the sake of the discussion, let's assume I have a c# class called "Visit" which contains a nullable DateTime field called "SynchronizedOn" and also let's assume that the Subsonic migration has created the corresponding "Visits" table and the "SynchronizedOn" field.

If I was to write the SQL query myself, I would write something like:

SELECT * FROM Visits WHERE SynchronizedOn IS NULL

When I use the following code:

var visits = myRepository.Find<Visit>(x => x.SynchronizedOn == null);

Subsonic turns it into the following SQL query:

SELECT * FROM Visits WHERE SynchronizedOn == null

which never returns any rows.

I tried the following code but it throws an error:

visits = repository.Find<Visit>(x => x.SynchronizedOn.HasValue);

I was able to use the following syntax:

var query = from v in repository.All<Visit>()
            where v.SynchronizedOn == null
            orderby v.CreatedOn
            select v;
visits = query.ToList<Visit>();

but it's not as nice an short as using the Find<T> method.

Anyone knows how I can specify the "SynchronizedOn IS NULL" condition in the Find<T> method?

© Stack Overflow or respective owner

Related posts about subsonic3

Related posts about simplerepository