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.M("Product","","MONGO");大家可以去了解一下这个M方法的源码和具体的参数是干什么用的, 这里有个小问题, 就是中间的参数是表前缀, 但是我为空了系统竟然使用mysql的表前缀,并且我mongo的配置里面也写了表前缀是为空的,都不行, 有知道的大神说一下,小弟感激不尽.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 我们可以加上去, 这样就解决了.
ThinkPHP 是一个免费开源的,快速、简单的面向对象的 轻量级PHP开发框架 ,创立于2006年初,遵循Apache2开源协议发布,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,已经成长为国内最领先和最具影响力的WEB应用开发框架,众多的典型案例确保可以稳定用于商业以及门户级的开发。