Laravel Artisan路线:调用引发MySQL错误

时间:2018-04-08 02:48:40

标签: php mysql laravel laravel-5

我使用Artisan通过命令行调用Laravel 5 Route。我按照这篇文章中的说明创建了一个命令行控制器:Call laravel controller via command line

当我在网络浏览器中导航到此路线时,我没有收到任何错误。此路由执行API调用,并使用我创建的名为Laravel的{​​{1}} Model将数据插入MySQL数据库。

当我可以从CLI调用我的路由时,如下:

Ticker

我收到$ php artisan route:call /d17059dfce4c09ef5e437b1d9455f7c6 错误(其中Laravel是路由调用的控制器中执行的第一个SQL命令,truncate 'tickers'是数据库中的表) ,陈述:

tickers

因为我在通过命令行执行此路由时似乎只是收到错误,所以我认为命令行脚本SQLSTATE[HY000] [2002] No such file or directory (SQL: truncate `tickers`) 必须存在一些问题,如下所示:

App\Console\Commands\CallRoute.php

非常感谢任何有关排除或解决此错误的帮助。提前谢谢。

4 个答案:

答案 0 :(得分:1)

您应该传递/d17059dfce4c09ef5e437b1d9455f7c6作为选项而不是参数。它将其解释为目录。

php artisan route:call --uri=/d17059dfce4c09ef5e437b1d9455f7c6

更新命令签名以包含uri选项:

protected $signature = 'route:call {--uri=}';

命令:

class CallRoute extends Command
{
    /**
     * The name and signature of the console command.
     *
     * @var string
     */
    protected $signature = 'route:call {--uri=}';

    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = 'php artsian route:call /route';

    /**
     * Create a new command instance.
     *
     * @return void
     */
    public function __construct()
    {
        parent::__construct();
    }

    /**
     * Execute the console command.
     *
     * @return mixed
     */
    public function handle()
    {
        $request = Request::create($this->option('uri'), 'GET');
        $this->info(app()->make(\Illuminate\Contracts\Http\Kernel::class)->handle($request));
    }
}

答案 1 :(得分:1)

尝试看看这个问题。

PDOException SQLSTATE[HY000] [2002] No such file or directory

当我的 php-cli 与mysql的连接出现问题时我遇到了类似的问题,而我的 php-fpm 工作正常(这也可能是你为什么不这样做的原因)在浏览器中导航到此路线时出现错误)。我必须在我的php-cli配置中启用mysql pdo扩展。

只需在控制台中运行php -v,如果您看到类似的内容:

PHP 7.2.1 (cli) (built: Jan  8 2018 23:39:24) ( NTS )

这可能意味着您必须为php-cli启用pdo支持

答案 2 :(得分:0)

也许你想说TRUNCATE TABLE tickers?你扔掉那张桌子上的所有东西吗?

答案 3 :(得分:0)

php artisan命令命令类的创建和对象(您创建的自定义命令)。这是为了获取可用命令和选项的列表。

您可能已添加数据库查询(truncate table tickers)任何命令文件构造函数(__construct())。