欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  php教程

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

程序员文章站 2022-04-20 10:20:41
...
由于业务需要, 最近我也开始学习了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元