2014-04-17 11:11
浏览 42

Laravel 4 - 选择相关型号

I have following table

Schema::create('jokes_categories', function(Blueprint $table) {

Schema::create('jokes', function(Blueprint $table) {
    $table->string('content', 200)->unique();;
    $table->enum('is_active', array('Y', 'N'));

In the jokes table category_id is a foreign key and it has a one-to-many relationship with jokes_categories

In the model I have the following:

class Joke extends \Eloquent {

    public static $rules = array();

    // Don't forget to fill this array
    protected $fillable = array();

    public function JokesCategory(){
         return $this->belongsTo('JokesCategory');

In the controller I have the following:

$jokes = Joke::all();

But it does not pull through joke_categories.name (I was under the impression that the model definition will directly help to pull related models)

What could be the solution?

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • duanlun2827 2014-04-17 11:25

    Your query is just on the Joke table.

    You could eagerload the categories ie.

    $jokes = Joke::with('JokesCategory')->get();

    See docs: http://laravel.com/docs/eloquent#eager-loading

    解决 无用
    打赏 举报
  • 查看更多回答(1条)

相关推荐 更多相似问题