草庐IT

php - Laravel - 多表全文搜索

coder 2023-10-18 原文

我正在为我们正在进行的项目使用 Laravel 4 和 Eloquent 模型。 数据库符合 3NF,一切正常。此外,所有 MySQL 表都从 InnoDB 切换回 MyISAM,因为 MySQL 版本 < 5.6(innodb="" 中的全文搜索仅支持="" 5.6="">

在创建一些数据库搜索过滤器时,我发现使用 Eloquent 模型与查询生成器相比存在一些不足。具体而言,尤其是当尝试对多个表中的列进行全文搜索时(并保持在 Eloquent 的对象上下文中)。

为简单起见,我们有以下数据库结构:

--projects
    --id
    --name
    --status
    --...
--users
    --id
    --...
--roles
    --id
    --project_id
    --user_id
    --...
--notes
    --id
    --project_id
    --user_id
    --note
    --....

以下代码(针对问题进行了简化和最小化)目前工作正常,但是全文搜索仅适用于一个表(projects 表)。

if (Request::isMethod('post'))
        {

                $filters = array('type_id','status','division','date_of_activation','date_of_closure');

                foreach ($filters as $filter) {
                    $value = Input::get($filter);
                    if (!empty($value) && $value != -1) {//-1 is the value of 'ALL' option
                        $projects->where($filter,'=',$value);
                    }
                }

                $search = Input::get('search');

                if (!empty($search)) {
                    $projects->whereRAW("MATCH(name,description) AGAINST(? IN BOOLEAN MODE)",array($search));
                }

        }


// more code here...
// some more filters...
// and at the end I am committing the search by using paginate(10)

return View::make('pages/projects/listView',
            array(
            "projects" => $projects->paginate(10)
            )
        );

我需要扩展全文搜索以包括以下列 - projects.name , projects.descriptionnotes.note . 当试图找到如何使用 Eloquent 实现它时,我们不断返回到查询生成器并运行自定义查询,这可以正常工作,但随后我们将面临这些问题/缺点:

  1. Query Builder 返回一个数组,而 Eloquent 返回模型对象。由于我们正在扩展每个模型以包含方法,我们真的不想放弃 Eloquent 模型的强大功能。而且我们真的不想使用 Eloquent Project::find($id)返回结果只是为了再次获取对象。
  2. 我们正在链接“where”方法以拥有任意数量的过滤器 分配给它以及代码的可重用性。好像在混 Eloquent 和 Query Builder 语句一起将打破我们的链接。
  3. 为了这个项目的一致性,我们希望所有的数据库查询 留在 Eloquent 内涵。

阅读 Laravel 的文档和 API,我找不到使用 Eloquent 运行原始 SQL 查询的方法。有 whereRAW()但还不够广泛。我认为这是设计造成的限制,但它仍然是一个限制。

所以我的问题是:

  1. 是否可以对来自多个表的列进行全文搜索,只能在 Eloquent 中进行。我在网上看到的每条信息都提到了使用查询生成器。
  2. 如果没有,是否可以使用查询生成器搜索并返回 Eloquent 对象? (无需对数组结果运行 Project::find($id))。
  3. 最后,是否可以链接 Eloquent 和 Query Builder where方法在一起,同时只提交使用 get()paginate(10)稍后。

我知道 Eloquent 和 Query Builder 是不同的生物。但如果可以混合使用两者,或者使用 Eloquent 运行原始 SQL 查询,我相信 Eloquent 模型会变得更加健壮。在我看来,仅使用 Query Builder 有点像未充分使用 Laravel 框架。

希望能对此有所了解,因为 Laravel 的论坛/社区似乎仍在发展,尽管我发现它是一个了不起的框架!

谢谢,我感谢您的任何意见 :)

最佳答案

首先你可以在你的模型中使用查询范围

public function scopeSearch($query, $q) 
{        
   $match = "MATCH(`name`, `description`) AGAINST (?)";
   return $query->whereRaw($match, array($q))
                ->orderByRaw($match.' DESC', array($q));  
}

这样可以得到“ Eloquent 收藏”作为返回

$projects = Project::search(Input::get('search'))->get();

然后,要同时搜索笔记,您可以创建一个更复杂的范围来加入笔记并在那里进行搜索。

关于php - Laravel - 多表全文搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21890849/

有关php - Laravel - 多表全文搜索的更多相关文章

  1. ruby-on-rails - Nokogiri:使用 XPath 搜索 <div> - 2

    我使用Nokogiri(Rubygem)css搜索寻找某些在我的html里面。看起来Nokogiri的css搜索不喜欢正则表达式。我想切换到Nokogiri的xpath搜索,因为这似乎支持搜索字符串中的正则表达式。如何在xpath搜索中实现下面提到的(伪)css搜索?require'rubygems'require'nokogiri'value=Nokogiri::HTML.parse(ABBlaCD3"HTML_END#my_blockisgivenmy_bl="1"#my_eqcorrespondstothisregexmy_eq="\/[0-9]+\/"#FIXMEThefoll

  2. ruby - 如何搜索有用的 ruby - 2

    寻找有用的ruby的好网站是什么? 最佳答案 AgileWebDevelopment列出插件(虽然不是ruby​​gems,我不确定为什么),并允许人们对它们进行评级。RubyToolbox按类别列出gem并比较它们的受欢迎程度。Rubygems有一个搜索框。StackOverflow对最有用的rails插件和ruby​​gems有疑问。 关于ruby-如何搜索有用的ruby,我们在StackOverflow上找到一个类似的问题: https://stacko

  3. ruby - 如何搜索、递增和替换 Ruby 字符串中的整数子字符串? - 2

    我有很多这样的文档:foo_1foo_2foo_3bar_1foo_4...我想通过获取foo_[X]的所有实例并将它们中的每一个替换为foo_[X+1]来转换它们。在这个例子中:foo_2foo_3foo_4bar_1foo_5...我可以用gsub和一个block来做到这一点吗?如果不是,最干净的方法是什么?我真的在寻找一个优雅的解决方案,因为我总是可以暴力破解它,但我觉得有一些正则表达式技巧值得学习。 最佳答案 我(完全)不懂Ruby,但类似这样的东西应该可以工作:"foo_1foo_2".gsub(/(foo_)(\d+)/

  4. ruby - Ruby 中的必应搜索 API - 2

    我读了"BingSearchAPI-QuickStart"但我不知道如何在Ruby中发出这个http请求(Weary)如何在Ruby中翻译“Stream_context_create()”?这是什么意思?"BingSearchAPI-QuickStart"我想使用RubySDK,但我发现那些已被弃用前(Rbing)https://github.com/mikedemers/rbing您知道Bing搜索API的最新包装器(仅限Web的结果)吗? 最佳答案 好吧,经过一个小时的挫折,我想出了一个办法来做到这一点。这段代码很糟糕,因为它是

  5. Ruby#index 方法 VS 二进制搜索 - 2

    给定一个元素和一个数组,Ruby#index方法返回元素在数组中的位置。我使用二进制搜索实现了我自己的索引方法,期望我的方法会优于内置方法。令我惊讶的是,内置的在实验中的运行速度大约是我的三倍。有Rubyist知道原因吗? 最佳答案 内置#indexisnotabinarysearch,这只是一个简单的迭代搜索。但是,它是用C而不是Ruby实现的,因此自然可以快几个数量级。 关于Ruby#index方法VS二进制搜索,我们在StackOverflow上找到一个类似的问题:

  6. ruby-on-rails - Sunspot:如何对具有不同值的多个字段进行全文查询? - 2

    我想用sunspot重现以下原始solr查询q=exact_term_text:fooORterm_textv:foo*ORalternate_text:bar*但我无法通过标准的太阳黑子界面理解这是否可能以及如何实现,因为看起来:fulltext方法似乎不接受多个文本/搜索字段参数我不知道将什么参数作为第一个参数传递给fulltext,就好像我通过了"foo"或"bar"结果不匹配如果我传递一个空参数,我得到一个q=*:*范围过滤器(例如with(:term).starting_with('foo*')(顾名思义)作为过滤器查询应用,因此不参与评分。似乎可以手动编写字符串(或者可能使

  7. ruby - 使用 Ransack 搜索枚举字段 - 2

    我有一个表,'jobs'和一个枚举字段'status'。status具有以下枚举集:enumstatus:[:draft,:active,:archived]使用ransack,我如何过滤表,比如说,所有事件记录? 最佳答案 你可以像这样在模型中声明自己的掠夺者:ransacker:status,formatter:proc{|v|statuses[v]}do|parent|parent.table[:status]end然后您可以使用默认的搜索语法_eq来检查相等性,如下所示:Model.ransack(status_eq:'ac

  8. ruby-on-rails - Rails 4 postgres 全文搜索错误(范围) - 2

    我一直在使用postgres关注railscast的全文搜索,但我不断收到以下错误#的未定义局部变量或方法“作用域”我关注了railscast确切地。我安装了所有正确的gem。(pg_search,pg)。这是我的代码文章Controller(我在这里也使用acts_as_taggable)defindex@articles=Article.text_search(params[:query]).page(params[:page]).per_page(3)ifparams[:tag]@articles=Article.tagged_with(params[:tag])else@art

  9. ruby - 如何使用部分字符串搜索数组并返回索引? - 2

    我想使用部分字符串搜索数组,然后获取找到该字符串的索引。例如:a=["Thisisline1","Wehaveline2here","andfinallyline3","potato"]a.index("potato")#thisreturns3a.index("Wehave")#thisreturnsnil使用a.grep将返回完整的字符串,使用a.any?将返回正确的true/false语句,但都不会返回匹配的索引找到了,或者至少我不知道该怎么做。我正在编写一段代码,该代码读取文件、查找特定header,然后返回该header的索引,以便它可以将其用作future搜索的偏移量。如果

  10. ruby-on-rails - 这个 C 和 PHP 程序员如何学习 Ruby 和 Rails? - 2

    按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我来自C、php和bash背景,很容易学习,因为它们都有相同的C结构,我可以将其与我已经知道的联系起来。然后2年前我学了Python并且学得很好,Python对我来说比Ruby更容易学。然后从去年开始,我一直在尝试学习Ruby,然后是Rails,我承认,直到现在我还是学不会,讽刺的是那些打着简单易学的烙印,但是对于我这样一个老练的程序员来说,我只是无法将它

随机推荐