文章详情页
yii2 mysql如何跨数据库联表查询?
浏览:159日期: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. 百度地图api - Android百度地图SDK,MapView上层按钮可见却不可触,怎么解决?2. vue.js - vue 打包后 nginx 服务端API请求跨域问题无法解决。3. javascript - 小米浏览器中,图片导致fixed定位的元素无法显示4. python3.x - 如何将python3.4的程序转为python2.75. 关于python的继承的一个疑问6. python - 如何在docker上部署pyspider7. java - 爬虫抓取问题8. java - socket类服务端如何防止被ddos攻击?9. Java。根据WSDL验证SOAP消息10. css3动画 - css3 animation初始动画卡顿是怎么回事?
排行榜

网公网安备