mongodb在windows下的安装步骤分享

 更新时间:2011年10月27日 22:24:01   作者:  
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的
nosql很火,mongodb做为一款优秀的分布式文件存储的数据库,也得到了不小的关注,http://weibo.com/k/mongodb 新浪微博中每天现在约有20多条信息。

官网:http://www.mongodb.org/
下载:http://www.mongodb.org/downloads
PHP扩展:http://cn.php.net/mongo

我选择了windows的安装包,下载了Windows 32-bit的1.8.2版本,以下是安装记录:

解压到了D:\www\mongodb

cd d:\www
bin\mongod.exe --dbpath=d:/www/mongodb/data

Sat Jul 09 09:03:28 [initandlisten] db version v1.8.2, pdfile version 4.5
复制代码 代码如下:

Sat Jul 09 09:03:28 [initandlisten] git version: 433bbaa14aaba6860da15bd4de8edf6
00f56501b
Sat Jul 09 09:03:28 [initandlisten] build sys info: windows (5, 1, 2600, 2, 'Ser
vice Pack 3') BOOST_LIB_VERSION=1_35
Sat Jul 09 09:03:28 [initandlisten] waiting for connections on port 27017
Sat Jul 09 09:03:28 [websvr] web admin interface listening on port 28017

这样mongodb就在运行了,但DOS操作还不能关闭,一关闭就停了。因此需要将其设为系统服务:
D:\www\mongodb>bin\mongod.exe --dbpath=d:/www/mongodb/data --logpath=d:/www/mongodb/mongodb.log --install
复制代码 代码如下:

all output going to: d:/www/mongodb/mongodb.log
Creating service MongoDB.
Service creation successful.
Service can be started from the command line via 'net start "MongoDB"'.

这样就可以在系统服务(services.msc)里就多了个MongoDB的服务,可以设置成 自动 来让windows每次启动时自动启动Mongo DB。
下面看其自带的客户端,仍然在其bin目录下,文件名为mongo.exe
bin\mongo.exe
复制代码 代码如下:

MongoDB shell version: 1.8.2
connecting to: test

在http://cn.php.net/mongo下载mongodb的php扩展,PHP 5.2 VC6 Thread-Safe Mongo extension。
5.2版只有5.2.13的mongodb.dll。本地php重装了5.2.13,可以用了。
主要代码:
复制代码 代码如下:

$m = new Mongo(); // 默认连接本机的27017端口
$mdb = $m -> hx; // 选择hx数据库,如果以前没有,则会自动创建,也可以用$m->selectDB("hx");
$collection = $mdb->hx_site; //选择hx里面的hx_site集合,相当于取hx库里的hx_site表,也可以使用$mdb->selectCollection("hx_site");
[html]
批量插入:
[code]
for($i=53;$i<84;$i++){
$start = $i * 10000;
$end = ($i+1) * 10000;
$sql = "SELECT * FROM hx_site WHERE id > $start AND id <= $end";
$tmp = $db->query($sql);
$arrs = array();
while ($arr = $db->fetch_array($tmp)) {
$arrs[] = $arr;
}
$collection->batchInsert($arrs);
}

用php将本地有83.6w条数据的mysql转成mongodb,每次插入1w条,一次需要109~125ms。
复制代码 代码如下:

/*
mysql语句对应的mongodb语法: https://www.jb51.net/article/28694.htm
取pagerank=5,按id倒序,取30条
类似于 SELECT * FROM hx_site WHERE pagerank = 5 ORDER BY id DESC LIMIT 30
*/
$cursor = $collection->find(array('pagerank'=>'5'))->sort(array('id'=>-1))->limit(30);
foreach ($cursor as $obj) { //遍历所有集合中的文档
echo $obj["id"].' '.$obj["domain"] . "<br>";
}

没索引的情况下取一条记录,656ms,mysql需要0.7s,基本上没区别。
count(*)某条件,800多ms,加索引后100多ms

相关文章

  • mongodb设置后台运行的方法

    mongodb设置后台运行的方法

    这篇文章主要介绍了mongodb设置后台运行的方法,本文同时给出了关闭已在后台运行mongodb的方法,需要的朋友可以参考下
    2014-09-09
  • 教大家8天学通MongoDB——第一天 基础入门篇

    教大家8天学通MongoDB——第一天 基础入门篇

    MongoDB是目前非常流行的一种非关系型数据库(NoSQL),因其操作简单、完全免费、源码公开等特点,受到了IT从业人员的青睐,并被广泛部署于实际的生产环境中。本文教大家8天学通MongoDB——第一天 基础入门篇,感兴趣的朋友一起来了解了解吧
    2015-09-09
  • MongoDB数据库基本概念解析

    MongoDB数据库基本概念解析

    这篇文章介绍了MongoDB数据库的一些基本概念,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-03-03
  • 使用centos系统中的crontab命令对mongodb定时备份恢复

    使用centos系统中的crontab命令对mongodb定时备份恢复

    编写centos脚本使用crontab命令对mongodb定时执行备份与恢复操作,并删除指定天数前的备份
    2018-03-03
  • 记一次Mongodb中admin数据库导致的事故

    记一次Mongodb中admin数据库导致的事故

    这篇文章主要给大家介绍了关于一次Mongodb中admin数据库导致的事故的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-03-03
  • MongoDB  数据模型的设计模式及优缺点

    MongoDB  数据模型的设计模式及优缺点

    这篇文章主要介绍了MongoDB  数据模型的设计模式,在实际开发中,大多数性能问题都可以追溯到糟糕的模型设计,官方也提供分享过文档模型设计的进阶技巧,这里简单翻译记录一下,需要的朋友可以参考下
    2022-12-12
  • MongoDB 常用的数据类型和基本操作

    MongoDB 常用的数据类型和基本操作

    这篇文章主要介绍了MongoDB 常用的数据类型和基本操作,帮助大家更好的理解和学习使用MongoDB数据库,感兴趣的朋友可以了解下
    2021-03-03
  • MongoDB的备份与恢复

    MongoDB的备份与恢复

    这篇文章主要介绍了MongoDB的备份与恢复,帮助大家更好的理解和学习使用MongoDB,感兴趣的朋友可以了解下
    2021-03-03
  • MongoDB在系统数据库local中无法创建用户的解决办法

    MongoDB在系统数据库local中无法创建用户的解决办法

    这篇文章主要给大家介绍了关于MongoDB在系统数据库local中无法创建用户的解决办法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • Mongo DB增删改查命令

    Mongo DB增删改查命令

    本文给大家汇总介绍了一下Mongo DB数据库的增删改查命令以及部分的示例,有需要的小伙伴可以参考下,希望对大家学习Mongo DB能够有所帮助
    2016-12-12

最新评论