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にてSELECT時にdate型のカラムから年齢を計算し取得する方法
MySQLにdate型のカラムに誕生年月日が格納されており、そこから年齢を計算し ...
-
-
MySQLでLIKE検索時に大文字・小文字・半角・全角全て区別したい
以前にMySQLであいまい検索時に大文字小文字は区別しないが、それ以外は全て区別 ...
-
-
ON DUPLICATE KEY UPDATE後にinsert_idを取得すると結果が0になる
MySQLでON DUPLICATE KEY UPDATE句指定し、データの登録 ...
-
-
MySQLでグループ化したものを条件で絞る(HAVING)
正規化したテーブルがあってその中には idとtagのカラムがある。 でtagの方 ...
-
-
MySQLで特定のテーブルにパーティショニング設定し高速化を図る方法
以前に他社が設計されたログ系のテーブルを拝見した際にパーティショニング設定が行わ ...