3

我正在尝试将邮件列表从 CSV 导入我的数据库。我的 Laravel 中有两个模型负责执行此操作:TargetMailing(一个Target有很多Mailings)

我正在使用带有 Beanstalkd 的队列系统。我在用着:

Queue::push('ImportCSV', array(
            'file' => $file->getClientOriginalName(),
            'target' => $name
    ));

推送我的工作,然后我有 ImportCSV 工作类:

class ImportCSV
{
public function fire($job, $data) 
{   
    Log::info("Starting to add {$data['target']} to database");

    $target = new Target();
    $target->name = $data['target'];
    $target->save();

    $reader = new \EasyCSV\Reader($data['file']);

    // There must be a Email field in CSV file
    /*if(!in_array('Email', $reader->getHeaders() ))
        throw new Exception("Email field not found", 1);*/

    while ($row = $reader->getRow())
    {
        $mailing = new Mailing();
        $mailing->target()->associate($target);
        $mailing->email = $row['Email'];
        $mailing->save();
    }

    Log::info("Mailing list {$target->name} added to database");

    $job->delete();
}
}

自从我在日志文件中收到这些消息以来,所有代码似乎都在工作

[2013-09-10 21:03:25] log.INFO: Starting to add TEst to database [] []
[2013-09-10 21:03:25] log.INFO: Mailing list TEst added to database [] []

但是没有记录添加到我的数据库中。我应该如何在工作中使用模型?例如,我已经在控制器中对其进行了测试,一切正常

4

1 回答 1

4

由于您没有看到其他错误,我认为这是一个环境问题。

第一 - 环境

确保您对php artisan queue:listen(或queue:work,如果适用)的调用使用正确的环境,以便使用正确的数据库:

$ php artisan queue:listen --env=YOUR_ENV

这是一篇关于在 Laravel 4 中设置队列的帖子,可能有助于了解更多信息。

第二 - 命名空间

由于您(显然?)没有看到任何 PHP 错误,这不太可能,但另一个想法是:

如果您的类是命名空间的,您可能需要使用该\字符来获取位于全局命名空间中的模型。

// From:
$mailing = new Mailing();

// To:
$mailing = new \Mailing();
于 2013-09-11T13:13:20.763 回答