TP3.2.3教你如何解决mongo无法连接的问题

原创
2016-06-07 11:36:08 1353浏览

由于业务需要, 最近我也开始学习了mongo, 公司用的3.2.3版本, 遇到最大的问题就是Call to a member function selectCollection() on a non-object, 其实看过错误提示就会很明白, 这个原因是由于缺少数据库名引起的.
知道了错误原因就很容易解决这个问题了.
首先, 我的数据库配置文件是这样写的:return array(
'DB_TYPE' => 'mysql',
'DB_HOST' => 'localhost',
'DB_NAME' => 'xxx',
'DB_USER' => 'xxx',
'DB_PWD' => 'xxx',
'DB_PORT' => '3306',
'DB_PREFIX' => '',
//密钥
"AUTHCODE" => 'xxx',
"COOKIE_PREFIX" => 'xxx',
'MONGO'=>array(
'DB_TYPE' => 'mongo', // 数据库类型
'DB_HOST' => 'localhost', // 服务器地址
'DB_NAME' => 'xxx', // 数据库名
'DB_USER' => 'xxx', // 用户名
'DB_PWD' => 'xxx', // 密码
'DB_PORT' => '27017', // 端口
'DB_PREFIX' => 'xx'
)
);
默认使用mysql的链接方式, 只有在某些页面才会用到mongo.
so 在使用的时候是这样: M("Product","","MONGO");大家可以去了解一下这个M方法的源码和具体的参数是干什么用的, 这里有个小问题, 就是中间的参数是表前缀, 但是我为空了系统竟然使用mysql的表前缀,并且我mongo的配置里面也写了表前缀是为空的,都不行, 有知道的大神说一下,小弟感激不尽.
然后就是修改Library\Think\Db\Driver\Mongo.class.php这个文件:
其中switchCollection函数里面有一段代码是这样的:if(!empty($db)) { // 传人Db则切换数据库
// 当前MongoDb对象
$this->_dbName = $db;
$this->_mongo = $this->_linkID->selectDb($db);
}
我们在其后面加个else:if(!empty($db)) { // 传人Db则切换数据库
// 当前MongoDb对象
$this->_dbName = $db;
$this->_mongo = $this->_linkID->selectDb($db);
}else{
$config = C('MONGO');
$db = $config['DB_NAME'];
$this->_dbName = $db;
$this->_mongo = $this->_linkID->selectDb($db);
}
开头我也说了, 造成这个错误的原因就是缺少数据库名, so 我们可以加上去, 这样就解决了.

AD:真正免费,域名+虚机+企业邮箱=0元

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。