我试图查询一个IList< string>属性我的一个域类使用NHibernate.以下是一个简单的示例:
public class Demo { public Demo() { this.Tags = new List<string>(); } public virtual int Id { get; set; } public virtual string Name { get; set; } public virtual IList<string> Tags { get; set; } }
像这样映射:
<class name="Demo"> <id name="Id" /> <property name="Name" /> <bag name="Tags"> <key column="DemoId"/> <element column="Tag" type="String" /> </bag>
我可以保存和检索很好.现在查询我的域类的实例,其中标签属性包含一个指定的值:
var demos = this.session.CreateCriteria<Demo>() .Createalias("Tags","t") .Add(Restrictions.Eq("t","a")) .List<Demo>();
导致错误:集合不是关联:Demo.Tags
var demos = (from d in this.session.Linq<Demo>() where d.Tags.Contains("a") select d).ToList();
导致错误:对象引用未设置为对象的实例.
var demos = this.session.createquery("from Demo d where :t in elements(d.Tags)") .SetParameter("t","a") .List<Demo>();
工作正常,但作为我真正的域类有许多属性,我正在构建一个复杂的动态查询,做丑陋的字符串操作不是我的第一选择.我更喜欢使用ICriteria或Linq.我有一个用户界面,可以输入许多不同的可能的搜索条件.现在建立ICriteria的代码是数十行.我真的很讨厌把它变成HQL字符串操纵.
解决方法
原文地址:https://www.jb51.cc/csharp/95651.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。