溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql中怎么實現跨庫關聯查詢

發布時間:2021-07-26 16:23:37 來源:億速云 閱讀:255 作者:Leah 欄目:數據庫

這篇文章將為大家詳細講解有關mysql中怎么實現跨庫關聯查詢,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

業務場景:關聯不同數據庫中的表的查詢

比如說,要關聯的表是:機器A上的數據庫A中的表A && 機器B上的數據庫B中的表B。

這種情況下,想執行“select A.id,B.id from A left join B on ~~~;“那是不可能的,但業務需求不可變,數據庫設計不可變,這就蛋疼了。。

解決方案:在機器A上的數據庫A中建一個表B。。。

這當然不是跟你開玩笑啦,我們采用的是基于mysql的federated引擎的建表方式。

建表語句示例:CREATE TABLE `table_name`(......) ENGINE =FEDERATED CONNECTION='mysql://[username]:[password]@[location]:[port]/[db-name]/[table-name]'

前提條件:你的mysql得支持federated引擎(執行show engines;可以看到是否支持)。

mysql中怎么實現跨庫關聯查詢

如果有FEDERATED引擎,但Support是NO,說明你的mysql安裝了這個引擎,但沒啟用,去my.cnf文件末添加一行  federated  ,重啟mysql即可;

如果壓根就沒有FEDERATED這一行,說明你的mysql就沒有安裝這個引擎,這就不能愉快的玩耍了,最好去找你們家運維搞定吧,因為接下來的動作比較大,而且我也不知道怎么搞;

解釋:通過FEDERATED引擎創建的表只是在本地有表定義文件,數據文件則存在于遠程數據庫中,通過這個引擎可以實現類似Oracle
下DBLINK的遠程數據訪問功能。就是說,這種建表方式只會在數據庫A中創建一個表B的表結構文件,表的索引、數據等文件還是在機器B上的數據庫B中,相當于只是在數據庫A中創建了表B的一個快捷方式。

關于mysql中怎么實現跨庫關聯查詢就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女