您的位置:首页技术文章
文章详情页

yii2 mysql如何跨数据库联表查询?

浏览:53日期:2022-06-18 09:30:50

问题描述

wp_post在blog_cn数据库中,而stat_weibo在task数据库中。现在两个数据表需要进行连表查询,该如何实现?

yii2 mysql如何跨数据库联表查询?

yii2 mysql如何跨数据库联表查询?

yii2 mysql如何跨数据库联表查询?

问题解答

回答1:

还要注意 这两个数据库在一个 mariadb实例 中。跨mariadb, 跨服务器做join是不行的

回答2:

重写ActiveRecord::getDb()方法,默认回去根据配置的db component来连接数据库。

回答3:

若两个数据库在同一个Mysql服务器中可以这样做

重写 Weibo model类的 tableName() 方法:

public static function tableName(){ preg_match('/dbname=([^;]+)/i', self::getDb()->dsn, $matches); return $matches[1].’.weibo’;}

若两个数据库不在同一个Mysql服务器中则暂时没有解决办法

相关文章: