2

我有两个表, modules(id,module_name)和 sub_modules (id,module_id,sub_module_name)。我想显示一个像这样结构的表:

Sub Module ID | Module Name | Sub Module Name

Modules.php(模型)

class Modules extends Eloquent {

 protected $table = 'modules';

 public function submodules()
 {
    return $this->hasMany('SubModules','module_id');
 }
}

SubModules.php(模型)

class SubModules extends Eloquent {

  protected $table = 'sub_modules';

  public function modules() {
    return $this->belongsTo('Modules');
  }

  public function nodes()
  {
    return $this->hasMany('Nodes','sub_module_id');
  }
}

AdminController.php(控制器)

  public function subModules() {
     return View::make('sub-modules',
                        array('title'=>'Sub-Modules',
                       'modules'=>Modules::all(),
                       'sub'=>Modules::with(array('submodules'))->get()                 
                      )
     );
  }

在我的子模块视图中,我正在获取这样的$sub变量:

@foreach ($sub as $sub)
   <tr class="gradeX">
      <td>
         <input type="checkbox" value="{{ $sub->id }}" id="check_{{ $sub->id }}"/>
      </td>
      <td>
         {{ $sub->module_name }} 
      </td>
      <td>
         {{ $sub->sub_module_name }} 
      </td>
      <td>
          <a onclick="edit_sub_module({{ $sub->id }})" title="Edit"><i class="icon-edit icon-2x"></i></a>
      </td>
    </tr>
@endforeach

它不显示 sub_modules table($sub->sub_module_name) 中的内容,仅显示模块中的内容。如何解决这个问题?而且id两个表中都有字段,我只需要 sub_modules 中的 id。

4

4 回答 4

2

解决了这个问题:

SubModules::join('modules', 'modules.id', '=','sub_modules.module_id')
->select('sub_modules.*','modules.module_name')->get‌​()

但是有人知道如何用雄辩的关系做到这一点吗?

于 2013-05-29T07:33:26.223 回答
0

这个怎么样:

public function subModules() {
     return View::make('sub-modules',
                        array('title'=>'Sub-Modules',
                       'modules'=>Modules::all(),
                       'sub'=>Modules::with('submodules')->get()                 
                      )
     );
  }
于 2014-01-30T22:08:23.287 回答
0

你可以调用你的 AdminController.php

$module = new \App\Module::find(1); // put needed module_id;
$submodules = $module->submodules()
    ->join('modules', 'modules.id', '=','sub_modules.module_id')
    ->select('sub_modules.*','modules.module_name')
    ->get‌​();

$module->submodules()返回Illuminate\Database\Eloquent\Relations\HasMany类并可以为其调用join(),select()等。

于 2015-08-06T13:26:09.493 回答
0

不使用“get()”无法获取子模块数据

$submoduledata = Module::find($id)->subModule()->get();

于 2015-09-16T11:56:22.837 回答