Discuz DB层跨库映射关系表名前缀BUG修复后产生的新bug

简介: 新的逻辑引入了新的bug,会导致在跨多库连接时,产生表名前缀映射混乱,需要再做逻辑上的修复。     function table_name($tablename) { if(!empty($this->map) && !empty($this->map[$table...

新的逻辑引入了新的bug,会导致在跨多库连接时,产生表名前缀映射混乱,需要再做逻辑上的修复。

 

 

function table_name($tablename) {
        if(!empty($this->map) && !empty($this->map[$tablename])) {
            $id = $this->map[$tablename];
            if(!empty($this->config[$id]['tablepre'])){
                $this->tablepre = $this->config[$id]['tablepre'];
            }
            if(!$this->link[$id]) {
                $this->connect($id);
            }
            $this->curlink = $this->link[$id];
        } else {
            $this->tablepre = $this->config['1']['tablepre'];
            $this->curlink = $this->link[1];
        }
        return $this->tablepre.$tablename;
    }

 

附db Map 写法:

$_config['db']['1']['dbhost'] = 'localhost'; // 服务器地址
$_config['db']['1']['dbuser'] = 'root'; // 用户
$_config['db']['1']['dbpw'] = 'root';// 密码
$_config['db']['1']['dbcharset'] = 'gbk';// 字符集
$_config['db']['1']['pconnect'] = '0';// 是否持续连接
$_config['db']['1']['dbname'] = 'x1';// 数据库
$_config['db']['1']['tablepre'] = 'pre_';// 表名前缀

$_config['db']['2']['dbhost'] = 'localhost';
.....

//再配置一些数据源
$_config['db']['xxx_sys']['dbhost'] = 'localhost';

//映射
$_config['db']['map']['yyy_table'] = 'xxx_sys';

 

上一篇文章:http://www.cnblogs.com/x3d/p/3913690.html

目录
相关文章
|
8月前
|
关系型数据库
Pg库增加&修改字段
Pg库增加&修改字段
133 0
|
SQL 关系型数据库 MySQL
mysql批量更新表前缀
mysql批量更新表前缀
160 0
mysql批量更新表前缀
|
关系型数据库 MySQL Java
mysql 表名和和数据库函数名称冲突的解决方法
好久没写blog了,今天刚考完网络后面还有一大段时间没考试可以学点技术了。但是,今天晚上被mysql卡了一晚上,,,因为我的表有一个叫show,因为我很少使用show这个函数。
410 0
mysql 表名和和数据库函数名称冲突的解决方法
|
SQL 数据库 数据库管理
Sqlite升级时向已有表中增加字段
Sqlite数据库升级时,我们经常会遇到给已有表中增加字段的操作。一般来说,**给已有表中增加字段**是数据库操作中的基操,没必要再专门写篇blog记录的,但是sqlite对SQL语句支持的不够彻底,比方说这次我们用到的"ALTER TABLE"命令。
|
Oracle 关系型数据库
6 Oracle 表的管理-表查询(重点)
利用scott用户存在的几张表(emp,dept)来演示如何使用select查询语句。
122 0
|
关系型数据库 MySQL 数据库
数据库中的表如何设置约束?(精简版)
数据库中的表如何设置约束?(精简版)
417 0
|
关系型数据库 MySQL
mysql如何把一张表的数据移植到另外一张和其结构一样的表中
mysql如何把一张表的数据移植到另外一张和其结构一样的表中
212 0
|
存储 SQL 关系型数据库
MySQL使用存储过程为数据库中全部的表增加备用字段
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u010046908/article/details/84879858 ...
1774 0
|
关系型数据库 MySQL Shell