繁体   English   中英

如何在使用两个不同数据库的 BD Query Laravel 中使用 Join?

[英]How to use Join in BD Query Laravel using two different databases?

我得到了这段代码以在页面中显示表格,但它不起作用。 我收到这个错误,说命令被拒绝。

$posts = DB::connection('mysql2')
->table('wp_rocketsciencebrposts')
->join('users', 'users.rsbwordpressid', '=', 'wp_rocketsciencebrposts.post_author')
->select('ID', 'post_title', 'post_status', 'post_author', 'post_date', 'users.name')
->whereIn('post_status', ['publish', 'private'])
->where('post_type', 'post')
->orderBy('id', 'desc')
->paginate(15, ['*'], 'posts');

SQLSTATE[42000]:语法错误或访问冲突:1142 SELECT 命令拒绝用户 'lovel095_heaven'@'177.134.6.23' 表 'users'(SQL:从wp_rocketsciencebrposts内选择计数(*)作为聚合内连接mysqlusers上的users . rsbwordpressid = mysql2 . wp_rocketsciencebrposts . post_author其中post_status in (publish, private) and post_type = post)

两个数据库都在同一台服务器上。

“wp_rocketsciencebrposts”来自“lovel095_rocketsciencebr”数据库。
“users”来自“lovel095_centralrsb”数据库。

在我的 .env 文件中,我 git 这个:

DB_CONNECTION=mysql
DB_HOST=br862.hostgator.com.br
DB_PORT=3306
DB_DATABASE=lovel095_centralrsb
DB_USERNAME=(myusername)
DB_PASSWORD=(mypassword)

DB_CONNECTION_SECOND=mysql
DB_HOST_SECOND=br862.hostgator.com.br
DB_PORT_SECOND=3306
DB_DATABASE_SECOND=lovel095_rocketsciencebr
DB_USERNAME_SECOND=(myusername)
DB_PASSWORD_SECOND=(mypassword)

在我的 config>database.php 文件中,我得到了这个:

'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' => true,
    'engine' => null,
    'options' => extension_loaded('pdo_mysql') ? array_filter([
        PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
    ]) : [],
],

'mysql2' => [
    'driver'    => env('DB_CONNECTION_SECOND'),
    'host'      => env('DB_HOST_SECOND'),
    'port'      => env('DB_PORT_SECOND'),
    'database'  => env('DB_DATABASE_SECOND'),
    'username'  => env('DB_USERNAME_SECOND'),
    'password'  => env('DB_PASSWORD_SECOND'),
],

请帮忙!

大多数数据库不支持跨数据库连接,我相信 SQL 服务器支持它,但它必须在同一台服务器上。 无需强制您的应用程序加入两个不同的数据库,只需单独使用数据库即可。

在您的情况下,只需先选择帖子,然后使用 foreach 选择用户名。 这是解决方法:

$posts = DB::connection('mysql2')
->table('wp_rocketsciencebrposts')
->select('ID', 'post_title', 'post_status', 'post_author', 'post_date')
->whereIn('post_status', ['publish', 'private'])
->where('post_type', 'post')
->orderBy('id', 'desc')
->paginate(15, ['*'], 'posts');

foreach ($posts as $key => $post){
    $user = DB::connection('mysql')
            ->table('lovel095_centralrsb')
            ->where('id', $post->post_author)
            ->first();
    $posts[$key]->post_author_name = $user->name;
}

您好,我不确定您是否需要配置 2 个数据库来执行这种查询。 只要确保您用于连接到一个数据库的凭据能够访问这两个数据库,它就可以与 MySql 一起使用。

从这里我建议您阅读其他 stackoverflow 答案

基本上,您需要使用数据库名称为表添加前缀以使连接工作。 我建议你先从 PhpMyAdmin 尝试这个,然后转换成 Laravel Query Builder。

请记住,您可以在查询构建器中使用整个原始查询,例如:

DB::select( DB::raw("SELECT * FROM some_table WHERE some_col = '$someVariable'") );

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM