文章详情页
yii2 mysql如何跨数据库联表查询?
浏览:236日期: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. java - 安卓调用c++lib2. css3 - 求css页面解决方案3. 如何解决docker宿主机无法访问容器中的服务?4. javascript - webpack构建工具重构代码的流程是怎么样的?5. javascript - 想做一个canvas的触摸画板,但屏幕会在画的时候滚来滚去,如何阻止?6. mysql 5个left关键 然后再用搜索条件 几千条数据就会卡,如何解决呢7. HTML5表单必填属性设置自定义验证消息?8. Java中main方法里面的参数一定要是String []args吗?9. java - 大家可以分享一下各自如何高效编程吗?就是一些常用的配置及习惯等等10. javascript - js 多维数组的问题
排行榜

网公网安备