MySQLで同一サーバーの異なるDB内のテーブルをJOINする
2024/01/07
同一の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とPHPの「image-comparator」ライブラリを使用して類似画像検索を実装する方法
先日PHPで画像を比較して類似度を算出する「image-comparator」ラ ...
-
-
MySQLで月別に集計を行う。あと日付時刻関数。
現在進行形でやっているデータ集計系だけど 新たな発見があったのでメモ。 ■日付時 ...
-
-
MySQLにて直近のクエリで発行されたAUTO_INCREMENTの値を取得する方法
やりたかったことは「MySQLで新規登録(INSERT)なら、登録時のAUTO_ ...
-
-
SSH接続でMySQLにダンプファイルをインポートする方法
phpMyAdminやAdminerが入っていなかったり、ダンプファイルのサイズ ...
-
-
phpmyadminからプロセスの停止
重たいSQL文を叩いた際、どうにも処理できず メモリ使用率が100%から下がらな ...