0

我在让 Laravel 的 Eloquent ORM 返回关系数据时遇到了真正的问题。

我的迁移(数据库模式):

Schema::table('users', function($table)
{
    $table->engine = 'InnoDB';
    $table->create();

    $table->increments('id')->unsigned();
    $table->string('firstname');
    $table->string('surname');
    $table->string('email')->unique();
    $table->string('password')->unique();
    $table->string('phone')->nullable();
    $table->text('about')->nullable();
    $table->timestamps();
});

Schema::table('files', function($table)
{
    $table->engine = 'InnoDB';
    $table->create();

    $table->increments('id')->unsigned();
    $table->string('filename');
    $table->string('title');
    $table->text('description')->nullable();
    $table->string('keywords')->nullable();
    $table->integer('category_id')->unsigned();
    $table->integer('file_type_id')->unsigned();
    $table->integer('user_id')->unsigned();
    $table->timestamps();
});

楷模

文件.php

<?php

class File extends Eloquent
{

    public static $timestamps = true;

    public function user()
    {
        return $this->belongs_to('User');
    }

}

用户.php

<?php

class User extends Eloquent
{
    public static $timestamps = true;

    public function files()
    {
        return $this->has_many('File');
    }
}

路由.php

// everything else in my routes.php is as it was when downloaded
Route::get('users', function()
{
    echo '<pre>';

    // this works
    $users = User::all();
    print_r($users);

    // this doesn't work
    print_r($users->files);

    // this doesn't work
    $files = User::find(1)->files;
    print_r($files);
});

错误:

未处理的异常

信息:

试图获取非对象位置的属性:

C:\wamp\www\l3_mlib\application\routes.php 第 51 行堆栈跟踪:

#0 C:\wamp\www\l3_mlib\laravel\laravel.php(42): Laravel\Error::native(8, '尝试获取 p...', 'C:\wamp\www\l3_.. .', 51) #1 C:\wamp\www\l3_mlib\application\routes.php(51): Laravel{closure}(8, '试图获取 p...', 'C:\wamp\www\ l3_...', 51, Array) #2 [内部函数]: {closure}() #3 C:\wamp\www\l3_mlib\laravel\routing\route.php(163): call_user_func_array(Object(Closure) , 数组)#4 C:\wamp\www\l3_mlib\laravel\routing\route.php(124): Laravel\Routing\Route->response() #5 C:\wamp\www\l3_mlib\laravel\laravel. php(167): Laravel\Routing\Route->call() #6 C:\wamp\www\l3_mlib\public\index.php(34): require('C:\wamp\www\l3_...' ) #7 {主要}

我究竟做错了什么?

4

2 回答 2

4

我对一个名为 Task 的模型也有同样的问题,它也是一个 Laravel 类。

在 application/config/application.php 中有一些删除命名空间的类别名。您可以注释掉文件别名,然后它不会与您的冲突。

如果你需要在任何时候使用 Laravel File 类,你可以通过它的命名空间名称来引用它,例如

Laravel\\File::get('path/to/file');

希望这可以帮助,

于 2013-03-06T10:51:26.013 回答
0

我认为问题出在您的迁移模式中,您没有设置外键,所以 laravel 无法获取对象数据,使用时

 $files = User::find(1)->files;

这就是为什么它返回错误:尝试获取非对象位置的属性

将此添加到您的文件迁移中,看看它是否有效

 $table->integer('user_id')->unsigned()->unique('user_id', 'files_user_id');
 $table->foreign('user_id')->references('id')->on('users');

并且您可以使用命名空间来避免类名冲突

于 2013-07-05T11:04:35.450 回答