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

浏览:4111 发布日期:2015/12/16 分类:功能实现 关键字: mongodb mongo thinkphp3.2.3 selectCollection
由于业务需要, 最近我也开始学习了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 我们可以加上去, 这样就解决了.
评论( 相关
后面还有条评论,点击查看>>