当前位置: 首页 > 知识库问答 >
问题:

Laravel Sail现有项目-未知数据库SQLSTATE[HY000][1049]

杜经艺
2023-03-14

我正在尝试使用Laravel Sail在本地完成一个现有项目。我不断收到1049未知数据库错误。我尝试了以下方法:

sail php artisan config:clear
sail php artisan config:cache

我也尝试过用mysql作为主机来使用127.1.1.0,比如.env.example文件,但是没有成功。

我也尝试过重建容器,但似乎没有解决问题。

这是我的. env文件(当我尝试使用根用户以外的用户时,我得到一个1045错误,说拒绝访问,不知道这些是否相关):

DB_CONNECTION=mysql
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=laravel
DB_USERNAME=root
DB_PASSWORD=

这是我的码头工人。yml文件:

mysql:
        image: 'mysql:8.0'
        ports:
            - '${FORWARD_DB_PORT:-3306}:3306'
        environment:
            MYSQL_ROOT_PASSWORD: '${DB_PASSWORD}'
            MYSQL_DATABASE: '${DB_DATABASE}'
            MYSQL_USER: '${DB_USERNAME}'
            MYSQL_PASSWORD: '${DB_PASSWORD}'
            MYSQL_ALLOW_EMPTY_PASSWORD: 'yes'
        volumes:
            - 'sailmysql:/var/lib/mysql'
        networks:
            - sail

数据库配置:

'mysql' => [
            'driver' => 'mysql',
            'url' => env('DATABASE_URL'),
            'host' => env('DB_HOST', '127.0.0.1'),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', 'forge'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'unix_socket' => env('DB_SOCKET', ''),
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '',
            'prefix_indexes' => true,
            'strict' => false,
            'engine' => null,
            'options' => extension_loaded('pdo_mysql') ? array_filter([
                PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
            ]) : [],
        ],

更新:

我在同一WSL安装的相邻目录中安装了laravel的新安装,并验证了docker compose。yml。env和数据库。php配置html" target="_blank">文件都是相同的。新的安装启动良好,我可以连接到数据库,现有的项目仍然无法工作。真的很困惑。。

共有1个答案

丌官和泰
2023-03-14

好的,经过大量的挖掘,我终于能够让它工作了。我将向未来发生这种情况的任何人解释我的发现。

我认为根本原因是,我试图在没有. env文件的情况下运行seinup命令,这会导致为mysql创建一个卷,并且当您有一个. env文件时不会重新创建。我在这里找到了这些信息,尽管提到的--rmi标志似乎对我没有任何帮助。

因此,我从手动删除卷开始。我从这个答案中得到了他们的位置。我认为手动删除它们是错误的步骤,但它们的位置如下:

\\wsl$\docker-桌面-数据\version-pack-数据\社区\docker\卷

下一次构建时,手动删除它们会导致另一个错误,但通过运行以下命令,我可以使用此处找到的信息解决此问题:

docker卷修剪

docker系统修剪

注意:我认为您可以在不手动删除卷的情况下运行这些卷,并且可能会得到相同的结果。通常,我认为您不希望从Windows资源管理器手动删除WSL中的文件。

一旦完成,我运行以下清除缓存和配置:

帆PHP工匠缓存:清除

sail php artisan配置:清除

(这些假设您在您的. bashrc文件中设置了扬帆别名,否则为./供应商/bin/扬帆...)。

然后我做了一个向下航行向上航行-d,然后是航行php artisan migrate,瞧,成功了!

 类似资料:
  • 问题内容: 使用PDO更新数据库时出现错误。我是PDO的新手,所以问题可能很小,我只是不明白。 关于错误的有趣的是,该命令可以正常运行,并且数据库确实得到了更新。 但是它仍然向我返回错误。 码: 错误: 错误更新内容:SQLSTATE [HY000]:一般错误 我真的不知道问题可能在哪里,因为它非常怪诞,而且我无法找到遇到相同问题的任何人。 问题答案: 您不使用fetchAll(),如 与更新或插

  • 我在运行时出现以下错误: Illumb\Database\QueryException:SQLSTATE[HY000]:一般错误:外键定义中有1个未知列“user\u id”(SQL:创建表“users”(“id”integer not null主键自动递增,“name”varchar not null,“email”varchar not null,“username”varchar not n

  • 问题内容: 我相信我已经将我的(非常基本的)站点成功部署到了fortrabbit,但是一旦我连接到SSH以运行一些命令(例如或),我就会收到一条错误消息: 在某个时候,迁移肯定已经成功了,因为我的表在那里-但这不能解释为什么它现在对我不起作用。 问题答案: 错误消息表明尝试了通过套接字的MySQL连接(不支持)。 在Laravel(工匠)的背景下,您可能想要使用其他/正确的环境。例如:(或任何环境

  • 我相信我已经成功地将我的(非常基本的)站点部署到fortrabbit,但是一旦我连接到SSH运行一些命令(如或),我就会出错留言: 在某种程度上,迁移肯定是有效的,因为我的表就在那里——但这并不能解释为什么它现在对我不起作用。

  • 问题内容: 我正在使用JDBC和它的新功能。但我不断收到此运行时异常: 这是给定的代码 如何使此代码起作用?我只是JDBC的初学者。 对于上面的代码;PASS =“ passowrd”,USER =“ root” 我在通过此站点修复的端口上遇到了问题 非常感谢 问题答案: 请在mysql数据库中检查数据库名称“ kholofedb ”是否存在 我想你还没有创造 请检查一次(如果没有创建)及其相关表

  • 我已经有一个在我的本地主机与数据库工作的laravel项目。但当我使用GCP应用程序引擎时,我遵循数据库连接的步骤。我已经在云中创建了mysql数据库,并从工作的本地数据库导入了所有sql。当我部署应用程序时,显示SQLSTATE[HY000][2002]下面没有这样的文件或目录是我的应用程序。yaml文件内容