首页  >  问答  >  正文

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

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

大家讲道理大家讲道理2743 天前820

全部回复(3)我来回复

  • 阿神

    阿神2017-04-17 15:43:34

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

    回复
    0
  • 高洛峰

    高洛峰2017-04-17 15:43:34

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

    回复
    0
  • 伊谢尔伦

    伊谢尔伦2017-04-17 15:43:34

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

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

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

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

    回复
    0
  • 取消回复