日期:2014-05-16 浏览次数:20558 次
<?php
ini_set('error_reporting', E_ALL | E_STRICT); //打开错误显示开关
//ini_set('error_reporting', 0); //关闭错误输出
$dburl = 'localhost';
$port= '27017';
$dbname = 'testdb';
$username = '';
$password = '';
$connection = new Mongo(); // connects to localhost:27017
//$connection = new Mongo( "$dburl:$port" ); // connect to a remote host (default port)
$db = $connection->selectDB($dbname);
$collection = $db->selectCollection('myc');
$doc = array( "name" => "MongoDB",
"type" => "database",
"count" => 1,
"info" => (object)array( "x"=>100, "y"=>200),
"versions" => array("0.9.7", "0.9.8", "1.4.0")
);
//$ret = $collection->insert($doc);
//遍历:
$cursor = $collection->find();
//var_dump($cursor); //object(MongoCursor)[5] 5个对象
//返回$collection集合中文档的数量
echo '文档条数:'. $collection->count();
//
echo '<br>';
foreach ($cursor as $val)
{
echo $val['_id']. ': '. $val['name'] .'--'. $val['type'].'--'
. $val['info']['x'] .'--'. $val['info']['y'] .'--'. $val['versions'][2] .'<br>';
}
//更新:
//
$collection->update(array("a"=>10), array('$set'=>array('a'=>10000)));
//
$options['multiple'] = true; //默认是 false,是否改变匹配的多行
$collection->update(
array("info.x"=>100),
array('$set'=>array('info.y'=>800)),
$options);
//按条件查找:
$query = array("a"=>10000);
$cursor = $collection->find($query); //在$collectio集合中查找满足$query的文档
while($cursor->hasNext())
{
var_dump($cursor->getNext()); //返回了数组
}
//$collection -> findOne(); //返回$collection集合中第一个文档
//$joe = $collection->findOne(array("_id" => $ret['_id']));
//删除一个数据库:
//$connection->dropDB("...");
//$connection->dropDB("...");
//列出所有可用数据库:
$m->listDBs(); //无返回值
//关闭连接:
$connection->close();
?>