0

我刚开始使用 Linq to NHibernate,并且遇到了一个非常简单的查询的问题。我有一个定义为 varchar 的数据库列。在 linq 查询中,我需要将该值与日期时间值进行比较(存储在 varchar 列中的所有值都是有效日期)。我正在尝试这个:

var list = (from o in session.Linq<ObjectName>() where Convert.ToDateTime(o.ColumnName) >= startDate select o).ToList();

当使用 Convert.ToDateTime 我得到这个异常:

不能在没有投影的条件上使用子查询。

at NHibernate.Criterion.SubqueryExpression.ToSqlString(ICriteria criteria, ICriteriaQuery criteriaQuery, IDictionary`2 enabledFilters)
at NHibernate.Criterion.Junction.ToSqlString(ICriteria criteria, ICriteriaQuery criteriaQuery, IDictionary`2 enabledFilters)
at NHibernate.Loader.Criteria.CriteriaQueryTranslator.GetWhereCondition(IDictionary`2 enabledFilters)
at NHibernate.Loader.Criteria.CriteriaJoinWalker..ctor(IOuterJoinLoadable persister, CriteriaQueryTranslator translator, ISessionFactoryImplementor factory, ICriteria criteria, String rootEntityName, IDictionary`2 enabledFilters)
at NHibernate.Loader.Criteria.CriteriaLoader..ctor(IOuterJoinLoadable persister, ISessionFactoryImplementor factory, CriteriaImpl rootCriteria, String rootEntityName, IDictionary`2 enabledFilters)
at NHibernate.Impl.SessionImpl.List(CriteriaImpl criteria, IList results)
at NHibernate.Impl.CriteriaImpl.List(IList results)   
at NHibernate.Impl.CriteriaImpl.List()
at NHibernate.Linq.CriteriaResultReader`1.List()   
at NHibernate.Linq.CriteriaResultReader`1.<GetEnumerator>d__0.MoveNext()
at System.Collections.Generic.List`1..ctor(IEnumerable`1 collection)   
at System.Linq.Enumerable.ToList[TSource](IEnumerable`1 source)

这是 NHibernate.Linq 的 1.0.0.4000。

4

1 回答 1

1

我会尝试将您的 varchar 列映射为 DateTime,实现 IUserType 来进行转换。我不知道您实际上是如何存储 DateTime 的(即什么表示形式),但请记住,数据库必须能够以两个日期时间比较的相同方式比较它们。例如,ISO-8601 表示的日期可以做到这一点。

于 2010-01-19T00:30:15.270 回答