勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

MySQLで同一サーバーの異なるDB内のテーブルをJOINする

   2024/01/07  MySQL

同一のMySQLサーバーでdb1データベースのtable1テーブルと、db2データベースのtable2テーブルを結合したかった。共有のカラムはidとする。以下に対応方法をメモ。

 

ソースコード

$mysqli = new mysqli($dbhost, $dbuser, $dbpass, 'db1');
$mysqli->set_charset('utf8');
$query = '
    SELECT * 
    FROM db1.table1 AS a 
    LEFT JOIN db2.table2 AS b 
    ON a.id = b.id
';

あとこれテストしてて気付いたんだけど、最初に接続するDBに関してはどこでもいいみたい。SELECT権限さえあれば、

$mysqli = new mysqli($dbhost, $dbuser, $dbpass, 'db3'); //実際に使うのはdb1とdb2だけど、db3を接続してもok
$mysqli->set_charset('utf8');
$query = '
    SELECT * 
    FROM db1.table1 AS a 
    LEFT JOIN db2.table2 AS b 
    ON a.id = b.id
';

という形でもいける。

また、同一ファイル内で異なるDBに接続したい場合は、いちいちcloseしてたけど「db名.table名」で書けばその必要は無かった。以下のような形。

$mysqli = new mysqli($dbhost, $dbuser, $dbpass, 'db3');
$mysqli->set_charset('utf8');
$query = '
    SELECT * 
    FROM db1.table1
';
$row = $mysqli->query($query);
while ($rs = $row->fetch_array(MYSQLI_ASSOC)) {
    var_dump($rs);
}
$query = '
    SELECT * 
    FROM db2.table2
';
$row = $mysqli->query($query);
while ($rs = $row->fetch_array(MYSQLI_ASSOC)) {
    var_dump($rs);
}

 

 - MySQL

  関連記事

MySQLにてdatetime型のカラムを整形し「年月日のみ形式」または「秒のみ省いた形式」で表示する方法

MySQLにてdatetime型のカラムに登録日時等を格納しており、管理画面側で ...

MySQLのRANK及びDENSE_RANK関数を用いてランキングを実装する方法

ランキング機能を実装する際、上位〇位までのデータをMySQLから持ってきて順位付 ...

MySQLでデータがあれば上書き、無ければ挿入する

既存のソースを編集時に「REPLACE INTO~~」 という見たことの無いSQ ...

PHPからMySQLにシリアライズしたデータを格納

アンケートフォームみたいなのがあって、 今後も定期開催し、尚且つ質問内容は増減す ...

MySQLで直近〇日、〇ヶ月、〇年以内のデータを検索する方法

他社が作成されたSQL文を見ているとDATE_ADDという使ったことの無い関数が ...