jen*_*ent 5 nhibernate join queryover
如何执行以下联接以返回有权访问公司ID的公司的用户.问题是在UserAccess和User之间没有使用User对象的明确关系,他们只是加入字符串属性Username:
User(Username, Name)
UserAccess(Username, Company)
Company(Id)
Session.QueryOver<Company>()
.Where(c => c.Id == companyId)
.JoinQueryOver<UserCompanyAccess>(u => u.UserAccessList)
.JoinQueryOver<User>(u => **Nope no property, just a string**
Run Code Online (Sandbox Code Playgroud)
Fir*_*iro 11
可以使用子查询完成
var subquery = QueryOver.Of<Company>()
.Where(c => c.Id == companyId)
.JoinQueryOver<UserCompanyAccess>(u => u.UserAccessList)
.Select(uca => uca.UserName);
var users = session.QueryOver<User>()
.WithSubquery.WhereProperty(u => u.Name).In(subquery)
.List();
Run Code Online (Sandbox Code Playgroud)
从 5.1.0 开始,hibernate 可以在未声明(未映射)的关系上生成实际的 sql 连接。例如,所有订单按客户支出排序:
var criteria = _session
.CreateCriteria<Order>("order");
criteria
.CreateEntityAlias(
"customer",
Restrictions.EqProperty("order.customerId", "customer._id"),
JoinType.LeftOuterJoin,
typeof(Customer).FullName)
.AddOrder(new Order("customer._lifetimeSpending", ascending:false));
return criteria.List<Order>();
Run Code Online (Sandbox Code Playgroud)
也可以使用 QueryOver (来自NHibernate 文档的示例):
Cat cat = null;
Cat joinedCat = null;
var uniquelyNamedCats = sess.QueryOver<Cat>(() => cat)
.JoinEntityAlias(
() => joinedCat,
() => cat.Name == joinedCat.Name && cat.Id != joinedCat.Id,
JoinType.LeftOuterJoin)
.Where(() => joinedCat.Id == null)
.List();
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
6057 次 |
最近记录: |