我正试图基于自定义ID结构的一个属性在RavenDb中查找文档:
struct UserId {
public int CompanyCode { get; set; }
public int EmployeeCode { get; set; }
}
class User {
public UserId Id { get; set; }
public string SomeData { get; set; }
}
class UserIdConverter : ITypeConverter {
public bool CanConvertFrom(Type t) { return t == typeof(UserId); }
public string ConvertFrom(string tag, object value, bool allowNull) { ... }
public object ConvertTo(string value) { ... }
}
此查询总是没有结果:
public User[] GetUsersByCompanyCode(int companyCode)
{
var users = (from u in _session.Query<User>()
where u.Id.CompanyCode == companyCode
select u).ToArray();
return users;
}
然而,此版本返回正确的结果:
public User[] GetUsersByCompanyCode(int companyCode)
{
var users = (from u in _session.Query<User>().ToArray()
where u.Id.CompanyCode == companyCode
select u).ToArray();
return users;
}
在不加载所有文档的情况下,实现这一目标的最佳方法是什么?
默认情况下,RavenDB使用Id
属性作为文档的标识,并且不支持复杂类型(据我所知)。我建议阅读使用文档标识符。
通常,您可以在Conventions.FindIdentityProperty
中更改标识属性的名称,但我建议更改UserId
属性的名称并使用类型为string
:的附加属性Id
class User {
public string Id { get; set; }
public UserId UserId { get; set; }
public string SomeData { get; set; }
}