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

标签 c# entity-framework stored-procedures full-text-search

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

我有一个代码优先的 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/

相关文章:

sql-server - 如何使用 SQL Server 将存储过程的结果存储在变量中

c# - 通过 WebAPI 正确序列化 LocalTime

c# - System.Timers.Timer 需要回到 'Main' 线程

c# - 使用 Entity Framework 忽略重复键插入

c# - 如何按ID自动重启列增量?

javascript - JDBC - MySQL 调用存储过程

c# - ContentPage 控件 (mv) --> MasterPage 访问

c# - 异步总是 WaitingForActivation

asp.net - 向 ASP.NET Identity 中的 AspNetUserRoles 表添加角色

sql-server - 如何在sql server中使用像pivote结果