Sql 在Laravel的控制器/视图中使用模型中的函数

Sql 在Laravel的控制器/视图中使用模型中的函数,sql,controller,laravel,laravel-4,models,Sql,Controller,Laravel,Laravel 4,Models,我正在尝试从我放置在模型中的函数中的查询中访问数据。我试图在控制器中调用该函数,然后将该数据发送到视图。到目前为止,我一直没有成功。代码如下: 型号:Fanartist.php public function fan_likes() { $fan_likes = DB::table('fanartists') ->join('artists', 'fanartists.fan_id', '=', 'artists.id')

我正在尝试从我放置在模型中的函数中的查询中访问数据。我试图在控制器中调用该函数,然后将该数据发送到视图。到目前为止,我一直没有成功。代码如下:

型号:Fanartist.php

public function fan_likes() {
        $fan_likes = DB::table('fanartists')
                    ->join('artists', 'fanartists.fan_id', '=', 'artists.id')
                    ->where('fanartists.fan_id', '=', Auth::user()->id)
                    ->select('artists.id', 'artists.stage_name', 'artists.city', 'artists.state', 'artists.image_path', 'artists.description');

           }
控制器:FansController.php

public function getHome() {
            return View::make('fans.home')
            ->with('fans', Fan::all())
            ->with('fanartists', Fanartist::fan_likes());

        }
视图:

@foreach($fanartists as $fanartist)

{{$fanartist}}

@endforeach
当我运行此操作时,我会得到以下错误:

Non-static method Fanartist::fan_likes() should not be called statically, assuming $this from incompatible context
谢谢你的帮助和建议

更新:

新错误。我正在返回视图,但现在尝试运行以下操作:

@foreach($fanartists as $fanartist)
                {{$fanartist->artists.id}}

            @endforeach
我得到一个错误:

Non-static method Fanartist::fan_likes() should not be called statically, assuming $this from incompatible context
log.ERROR:exception“ErrorException”,在/Applications/MAMP/htdocs/crowdsets/laravel master/app/storage/views/2ed7fc8952dab08cf4cb4f4e3d40d1ab:100中显示消息“正在尝试获取非对象的属性”

更新2:

运行:

@foreach($fanartists as $fanartist)
<?php var_dump($fanartist); ?>          
            @endforeach
fanArtister::fan_likes()
不应静态调用,但如果要静态调用,请将fan_likes函数更改为静态。 以你为例

public static function fan_likes() {
    $fan_likes = DB::table('fanartists')
                ->join('artists', 'fanartists.fan_id', '=', 'artists.id')
                ->where('fanartists.fan_id', '=', Auth::user()->id)
                ->select('artists.id', 'artists.stage_name', 'artists.city', 'artists.state', 'artists.image_path', 'artists.description');
return $fan_likes;
       }

如果在MyClass控制器中有这样一个非静态函数:

    public function my_func( ) {
            // do stuff
    return ( $stuff ) ;
}
然后在控制器中,您可以使用如下代码调用它:

$local_obj = MyClass::findOrFail( $myobj_id );
$rval = $local_obj->my_func();
{{{$data['my_obj']->my_func() }}}
如果要从视图调用它,我认为需要将对象传递到视图,如下所示:

$data['my_obj'] = $local_obj;
return View::make('view_name.show')->with('data',$data);
然后在视图中使用如下内容:

$local_obj = MyClass::findOrFail( $myobj_id );
$rval = $local_obj->my_func();
{{{$data['my_obj']->my_func() }}}

(以上是从工作代码中复制和编辑的-如果我输入了错,则为apols)

Ok,现在我在视图中得到了错误:[2013-07-07 18:17:30]log.error:exception'ErrorException'和消息'Invalid argument supplied for foreach()'在/Applications/MAMP/htdocs/crowdsets/laravel master/app/storage/views/2ed7fc8952dab08cf4cb4cf4fe3d40d1ab:99中出现了错误。因为$fanartists为空。在你的fan_likes()函数中,你没有返回任何东西,是的,这就是问题所在。我用一个新的错误更新了我的问题:我无法访问{{$fanartist->artists.id}或任何其他列…错误状态全部尝试转储$fanartists,查看它包含什么?它是一个对象吗?嗯,当我尝试时它不会运行页面:不知道你在做什么??只需在您的视图中尝试
并对其他内容进行注释即可。当我运行该操作时,我得到:网站在检索时遇到错误。它可能因维护而停机或配置不正确。让我们