yii2 mysql如何跨数据库联表查询?
大家讲道理
大家讲道理 2017-04-17 15:41:34
0
3
811

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

大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

全部回复(3)
阿神

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

小葫芦

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

伊谢尔伦

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

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

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

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!