3

在全新安装 Laravel 并运行 Valet 时,应用程序运行良好。

问题是尝试使用 MySQL 设置数据库。我可以创建一个数据库,告诉 MySQL 使用它,但不能用它做任何事情:

mysql> create database foobar;
Query OK, 1 row affected (0.09 sec)

mysql> use foobar;
Database changed

mysql> show tables;
ERROR 1449 (HY000): The user specified as a definer ('mysql.infoschema'@'localhost') does not exist

如果我尝试php artisan migrate,我会得到以下信息:

PDOException  : SQLSTATE[HY000] [2006] MySQL server has gone away

  at /Users/isaacfennell/Sites/anything/vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php:68
    64|         if (class_exists(PDOConnection::class) && ! $this->isPersistentConnection($options)) {
    65|             return new PDOConnection($dsn, $username, $password, $options);
    66|         }
    67|
  > 68|         return new PDO($dsn, $username, $password, $options);
    69|     }
    70|
    71|     /**
    72|      * Determine if the connection is persistent.

  Exception trace:

  1   PDO::__construct("mysql:host=127.0.0.1;port=3306;dbname=anything", "root", "", [])
      /Users/isaacfennell/Sites/anything/vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php:68

  2   Illuminate\Database\Connectors\Connector::createPdoConnection("mysql:host=127.0.0.1;port=3306;dbname=anything", "root", "", [])
      /Users/isaacfennell/Sites/anything/vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php:98

  Please use the argument -v to see more details.

我是 Laravel 和 MySQL 的新手,不知道如何解决这个问题——这是怎么回事?谢谢

4

3 回答 3

2

解决了第一个问题:

mysql_upgrade -u root

在这里找到:Mysql 错误:尝试转储表空间时,指定为定义者的用户 ('mysql.infoschema'@'localhost') 不存在'

但是运行php artisan migrate仍然会给出与上面相同的错误输出......</p>

于 2018-07-26T23:05:44.073 回答
0

如果您使用的是 mac,请在终端中写入:

composer global require "laravel/installer"(enter)
nano .bash_profile(enter)

按下i按钮,这样你就可以写了

export PATH="$PATH:$HOME/.composer/vender/bin"

按下alt+commandenter 按下x按钮退出

然后,打开你的 XAMPP,点击常规,点击打开终端,点击终端并输入:

pwd (enter)
cd space .. (enter)
cd opt/ 
cd lampp (even if you are using xampp)
cd htdocs
cd ur laravel folder name
php artisan migrate

https://www.youtube.com/watch?v=BUFyKk-GrvI&t=18s

我希望它会工作

于 2020-08-22T20:57:36.820 回答
-1

我还遇到了第二个问题,我通过创建和使用新的 MySQL 用户而不是使用root.

    mysql> CREATE USER 'newuser'@'localhost' IDENTIFIED BY 'newpassword';
    mysql> GRANT ALL PRIVILEGES ON anything.* TO 'newuser'@'localhost';

不要忘记更新应用程序的 .env 文件中的DB_USERNAMEand DB_PASSWORD,您可以在根目录中找到该文件。

于 2018-07-30T19:15:31.560 回答