gpt4 book ai didi

c# - 带有存储过程的代码优先 Entity Framework 从复杂的全文搜索返回结果

转载 作者:可可西里 更新时间:2023-11-01 03:07:50 24 4
gpt4 key购买 nike

我正在为以下场景寻找设计建议:

我有一个代码优先的 EF5 MVC 应用程序。我正在构建一个全文搜索功能,它将合并来自许多表的多个加权列。由于我无法使用这些表(其中一些包含文本/二进制列)的索引创建 View ,因此我创建了一个存储过程,它将输出我的对象的 ID(例如 PersonID)和根据搜索词对与该对象关联的排名。

我目前的方法是创建一个辅助类来执行全文搜索,它调用存储过程并根据返回的 ID 从上下文中加载所有对象。

我的问题是:

  1. 我的方法是否合理/遵循合理的最佳实践?
  2. 有没有其他人做过类似的事情并吸取了教训?
  3. 有没有一种方法可以更有效地做到这一点(即让存储过程的结果直接返回/映射到实体而不需要额外的查找?)

更新

将我的详细实现从问题的编辑移到它自己的答案中,以更符合@meta.stackexchange.com 经常推荐的内容

最佳答案

  1. 鉴于您不能首先将 containstable 等 SQL 方法与 Entity Framework 代码一起使用,而您的应用程序的其余部分可能会使用这些代码,因此您可能会“被迫”使用您描述的存储过程执行某些操作。我不知道这是否是最佳做法。不管它如何完成工作,我不明白为什么它不明智。
  2. 是的 - 我已经并且仍在围绕 EF codefirst 构建一个项目,我必须在其中进行相当复杂的搜索,其中包括几个标记为“必须拥有”的搜索参数和几个标记为“最好有”的值,并且在从中返回一个加权结果。
  3. 根据结果集的复杂性,我认为您不需要对数据库进行第二次往返,我将在下面向您展示我一直在做的一种方法。

请记住,下面只是一个示例:

    public List<Person> GetPeople(params string[] p)
{
var people = new List<Person>();

using (var db = new DataContext())
{
var context = ((IObjectContextAdapter)db).ObjectContext;

db.Database.Connection.Open();

var command = db.Database.Connection.CreateCommand();
command.CommandText = "SomeStoredProcedureReturningWeightedResultSetOfPeople";
command.CommandType = System.Data.CommandType.StoredProcedure;

//Add parameters to command object

people = context.Translate<Person>(command.ExecuteReader()).ToList();
}

return people;
}

即使存储过程有一个权重值列,在您翻译它时它也不会被映射。如果需要,您可以从 Person 派生一个包含权重值的类。

关于c# - 带有存储过程的代码优先 Entity Framework 从复杂的全文搜索返回结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14243946/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com