簡體   English   中英

在Laravel 4中跨多個表進行全文搜索

[英]Full text search in laravel 4 across multiple tables

我有一個正在處理的項目,需要在數據庫中的多個表上進行全文搜索。 我在這里找到了有用的教程:

http://creative-punch.net/2013/12/implementing-laravel-4-full-text-search

我可以在一張桌子上使用它,但是現在希望擴展到多個桌子上。 我遇到的問題是; 如果重復表的其余內容,當我點擊Submit時,如何獲得檢查多個控制器的按鈕? 或修改現有控制器以檢查多個表?

默認視圖形式

<div class="search">
    {{ Form::model(null, array('route' => array('search'))) }}
    {{ Form::text('query', null, array( 'placeholder' => 'Search query...' )) }}
    {{ Form::submit('Search') }}
    {{ Form::close() }} 
</div>

返回視圖

<div class="search">
    {{ Form::model(null, array('route' => array('search'))) }}
    {{ Form::text('query', null, array( 'placeholder' => 'Search query...' )) }}
    {{ Form::submit('Search') }}
 @foreach($posts as $post)
    <li>{{ $post->instance_id }}</li>
    <li>{{ $post->instance_type }}</li>
    <li>{{ $post->availability_zone }}</li>
    <li>{{ $post->status_checks }}</li>
    <li>{{ $post->alarm_status }}</li>
    <li>{{ $post->public_dns }}</li>
    <li>{{ $post->key_name }}</li>
 @endforeach
{{ Form::close() }}
</div>

控制器類

<?php 
class PostsController extends BaseController {

public function postSearch(){
    $q = Input::get('query');

   $posts =     ec2_instance::whereRaw("MATCH(instance_id,instance_type,availability_zone, status_checks,alarm_status, public_dns, key_name ) AGAINST(? IN BOOLEAN MODE)", 
        array($q))->get();
        View::share('posts', $posts);

    return View::make('ec2_instance', compact('posts'));

}
}
?>

我最初的想法是修改控制器,以便您添加:

 $ip_address = public_ip::whereRaw("MATCH(ip_address) AGAINST(? IN BOOLEAN      MODE)",     
         array($q))->get();'

然后在視圖中添加

     @foreach($ip_address as $ip)
         <li>{{ $ip->ip_address}}</li>
     @endforeach

但是找不到變量ip_address

我要返回2個視圖,按照我最初的想法,這是不可能的,以確保您僅返回1個視圖,即

$posts = ec2_instance::whereRaw("MATCH(instance_id,instance_type,availability_zone, status_checks,alarm_status, public_dns, key_name ) AGAINST(? IN BOOLEAN MODE)", array($q))->get();



 $ip_address =
 public_ip::whereRaw("MATCH(ip_address ) AGAINST(? IN BOOLEAN MODE)",           array($q))->get();


$s3_bucket = 
 s3_bucket::whereRaw("MATCH(name, storage_class, size ) AGAINST(? IN BOOLEAN MODE)", array($q))->get();

 $cloudfront_distribution =    cloudfront_distribution::whereRaw("MATCH(delivery_method, cloudfront_id, domain_name,comment, origin, c_name, status, state ) AGAINST(? IN BOOLEAN MODE)", array($q))->get();

return View::make('ec2_instance', compact('ip_address', 'posts','s3_bucket', 'cloudfront_distribution'));

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM