如何拆分字符串字段并使用 nhibernate queryOver 检查它是否包含指定的字符串?
How to split a string field and check if it contains a specified string using an nhibernate queryOver?
我正在尝试使用 NHibernate QueryOver return 结果,其中带有逗号分隔字符串的列 (DoNotDisplay) 不包含特定字符串,例如“3”。
我尝试了以下方法:
var query = session.QueryOver<Host>()
.Where(h => !h.systemsNotToBeShown.Split(',').Contains("3"));
主机 class 包含以下内容:
public virtual string systemsNotToBeShown { get; set; }
映射如下:
<property name="systemsNotToBeShown" column="DoNotDisplay" />
这 return 是以下异常:
Unrecognised method call: System.Linq.Enumerable:Boolean Any[TSource](System.Collections.Generic.IEnumerable`1[TSource], System.Func`2[TSource,System.Boolean])
我还尝试将映射的 属性 设置为私有并在 class 本身中创建一个列表,然后从该列表中进行比较,如下所示:
private virtual string _systemsNotToBeShown { get; set; }
public virtual List<int> SystemsNotToBeShown
{
get
{
return string.IsNullOrEmpty(_systemsNotToBeShown) ? new List<int>() : _systemsNotToBeShown.Split(',').Select(Int32.Parse).ToList();
}
set { }
}
映射也进行了适当的更改。
然后我尝试将查询更改为以下内容:
var query = session.QueryOver<Host>()
.Where(h => !h.SystemsNotToBeShown.Contains(3));
然后我得到以下异常:
Unrecognised method call: System.Collections.Generic.List`1[[System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=xxxxxxx]]:Boolean Contains(Int32)
我不确定我做错了什么。任何帮助都会很棒。
我通过执行以下操作设法解决了这个问题:
var queryString = "( ( (select position('" + sourceId + "' in trim(NODISPONSYSTEM) ) > 0 from system.iota) = false) or trim(NODISPONSYSTEM) is null) ";
然后使用以下行将其添加到 QueryOver:
.And(NHibernate.Criterion.Expression.Sql(queryString))
我正在尝试使用 NHibernate QueryOver return 结果,其中带有逗号分隔字符串的列 (DoNotDisplay) 不包含特定字符串,例如“3”。
我尝试了以下方法:
var query = session.QueryOver<Host>()
.Where(h => !h.systemsNotToBeShown.Split(',').Contains("3"));
主机 class 包含以下内容:
public virtual string systemsNotToBeShown { get; set; }
映射如下:
<property name="systemsNotToBeShown" column="DoNotDisplay" />
这 return 是以下异常:
Unrecognised method call: System.Linq.Enumerable:Boolean Any[TSource](System.Collections.Generic.IEnumerable`1[TSource], System.Func`2[TSource,System.Boolean])
我还尝试将映射的 属性 设置为私有并在 class 本身中创建一个列表,然后从该列表中进行比较,如下所示:
private virtual string _systemsNotToBeShown { get; set; }
public virtual List<int> SystemsNotToBeShown
{
get
{
return string.IsNullOrEmpty(_systemsNotToBeShown) ? new List<int>() : _systemsNotToBeShown.Split(',').Select(Int32.Parse).ToList();
}
set { }
}
映射也进行了适当的更改。
然后我尝试将查询更改为以下内容:
var query = session.QueryOver<Host>()
.Where(h => !h.SystemsNotToBeShown.Contains(3));
然后我得到以下异常:
Unrecognised method call: System.Collections.Generic.List`1[[System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=xxxxxxx]]:Boolean Contains(Int32)
我不确定我做错了什么。任何帮助都会很棒。
我通过执行以下操作设法解决了这个问题:
var queryString = "( ( (select position('" + sourceId + "' in trim(NODISPONSYSTEM) ) > 0 from system.iota) = false) or trim(NODISPONSYSTEM) is null) ";
然后使用以下行将其添加到 QueryOver:
.And(NHibernate.Criterion.Expression.Sql(queryString))