ElasticSearch NEST return 个特定字段
ElasticSearch NEST return specific fields
我正在尝试编写一个只返回其中一个字段的查询。现在我正在存储文件的文件路径和文件的内容,在我的搜索中我想搜索内容,但只有 return 文件路径。
我从这个声明开始:
var searchResults = client.Search<File>(
s => s.Query(q => q.Wildcard(w => w.Value("*" + genre + "*").OnField("fileContents"))).AllIndices().AllTypes());
returns 导致 searchResults.Documents
并向其添加 .Fields:
var searchResults = client.Search<File>(
s => s.Query(q => q.Wildcard(w => w.Value("*" + genre + "*").OnField("fileContents"))).AllIndices().AllTypes().Fields(f=>f.filePath));
它在 searchResults.Documents
中没有任何内容,但它使用 searchResults.Hits.Total
.
正确显示了命中数
文件 class 只是:
public class File
{
public string filePath { get; set; }
public string fileContents { get; set; }
}
这会生成以下 json 请求:
{
"fields": [
"filePath"
],
"query": {
"wildcard": {
"fileContents": {
"value": "*int*"
}
}
}
}
当 运行 在 Sense returns 的结果和当做 searchResults.Hits.Total
给出命中数时。
但是,searchResults.Document
IEnumerable 中没有记录。
有没有其他方法可以让我 return 进入一个特定的领域?
使用"source" 字段指定要撤回的字段。这是我的应用程序的示例代码,其中只有 returns 一些字段。
var searchResults = ElasticClient.Search<AuthForReporting>(s => s
.Size(gridSortData.PageSize)
.From(gridSortData.PageIndex * gridSortData.PageSize)
.Sort(sort)
.Source(sr => sr
.Include(fi => fi
.Add(f => f.AuthEventID)
.Add(f => f.AuthResult.AuthEventDate)
.Add(f => f.AuthInput.UID)
.Add(f => f.AuthResult.CodeID)
.Add(f => f.AuthResult.AuthenticationSuccessful)
.Add(f => f.AuthInput.UserName)
.Add(f => f.AuthResult.ProductID)
.Add(f => f.AuthResult.ProductName)
.Add(f => f.AuthInput.AuthType)
.Add(f => f.AuthResult.Address.City)
.Add(f => f.AuthResult.Address.State)
.Add(f => f.AuthResult.Address.CountryCode)
.Add(f => f.AuthResult.RulesFailed)
)
)
.Query(query)
);
然后您通过结果中的 "source" 访问字段:
var finalResult = from x in searchResults.Hits
select new AlertListRow
{
AlertCode = x.Source.AlertCode,
AlertDate = x.Source.AlertDate,
AlertID = x.Id,
AlertSummary = x.Source.Subject,
AlertMessage = x.Source.Body
};
我正在尝试编写一个只返回其中一个字段的查询。现在我正在存储文件的文件路径和文件的内容,在我的搜索中我想搜索内容,但只有 return 文件路径。
我从这个声明开始:
var searchResults = client.Search<File>(
s => s.Query(q => q.Wildcard(w => w.Value("*" + genre + "*").OnField("fileContents"))).AllIndices().AllTypes());
returns 导致 searchResults.Documents
并向其添加 .Fields:
var searchResults = client.Search<File>(
s => s.Query(q => q.Wildcard(w => w.Value("*" + genre + "*").OnField("fileContents"))).AllIndices().AllTypes().Fields(f=>f.filePath));
它在 searchResults.Documents
中没有任何内容,但它使用 searchResults.Hits.Total
.
文件 class 只是:
public class File
{
public string filePath { get; set; }
public string fileContents { get; set; }
}
这会生成以下 json 请求:
{
"fields": [
"filePath"
],
"query": {
"wildcard": {
"fileContents": {
"value": "*int*"
}
}
}
}
当 运行 在 Sense returns 的结果和当做 searchResults.Hits.Total
给出命中数时。
但是,searchResults.Document
IEnumerable 中没有记录。
有没有其他方法可以让我 return 进入一个特定的领域?
使用"source" 字段指定要撤回的字段。这是我的应用程序的示例代码,其中只有 returns 一些字段。
var searchResults = ElasticClient.Search<AuthForReporting>(s => s
.Size(gridSortData.PageSize)
.From(gridSortData.PageIndex * gridSortData.PageSize)
.Sort(sort)
.Source(sr => sr
.Include(fi => fi
.Add(f => f.AuthEventID)
.Add(f => f.AuthResult.AuthEventDate)
.Add(f => f.AuthInput.UID)
.Add(f => f.AuthResult.CodeID)
.Add(f => f.AuthResult.AuthenticationSuccessful)
.Add(f => f.AuthInput.UserName)
.Add(f => f.AuthResult.ProductID)
.Add(f => f.AuthResult.ProductName)
.Add(f => f.AuthInput.AuthType)
.Add(f => f.AuthResult.Address.City)
.Add(f => f.AuthResult.Address.State)
.Add(f => f.AuthResult.Address.CountryCode)
.Add(f => f.AuthResult.RulesFailed)
)
)
.Query(query)
);
然后您通过结果中的 "source" 访问字段:
var finalResult = from x in searchResults.Hits
select new AlertListRow
{
AlertCode = x.Source.AlertCode,
AlertDate = x.Source.AlertDate,
AlertID = x.Id,
AlertSummary = x.Source.Subject,
AlertMessage = x.Source.Body
};