文章详情页
yii2 mysql如何跨数据库联表查询?
浏览:133日期:2022-06-18 09:30:50
问题描述
wp_post在blog_cn数据库中,而stat_weibo在task数据库中。现在两个数据表需要进行连表查询,该如何实现?
问题解答
回答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服务器中则暂时没有解决办法
上一条:mysql怎么修改约束啊下一条:mysql多级联动表设计
相关文章:
1. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题2. docker镜像push报错3. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!4. 关于docker下的nginx压力测试5. dockerfile - [docker build image失败- npm install]6. angular.js - angular内容过长展开收起效果7. python - pyqt多线程问题实在不是很明白。。求解。。8. python中def定义的函数加括号和不加括号的区别?9. 【python小白】 问关于之初始化一次对象的问题10. python - (初学者)代码运行不起来,求指导,谢谢!
排行榜
