热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MongoDB数据库的安装与使用

MongoDB在官网上直接下载二进制包mongodb-linux-i686-1.8.0.tgz,直接解压缩就可以运行了。tarzxvfmongodb-linux-i686-1.8.0.tgzcdmongodb-linux-i686-1.8.0/binmkdir-p~/data/db/1、服务端运行:./mongod--
MongoDB在官网上直接下载二进制包mongodb-linux-i686-1.8.0.tgz,直接解压缩就可以运行了。

tar zxvf mongodb-linux-i686-1.8.0.tgz

cd mongodb-linux-i686-1.8.0/bin

mkdir -p ~/data/db/

1、服务端运行:

./mongod --dpath ~/data/db &

启动后出一些提示信息。

2、客户端:

./mongo

>

使用方法和mysql 很像,如:

show dbs —— show databases;

show collectioins —— show tables;

use —— use

增加、删除、查找、修改命令格式如下:

db..command

1)增加

> db.foo.save({a:11})

此时,MongoDB会建立foo collection,并将记录{a:11}插入foo中。同时会给该记录分配一个_id,如:

"_id" : ObjectId("4d8aaa03b2f4ee80e14f59aa")

注:MongoDB中的一条记录可以是任何形式的JSON串,关于JSON的说明请参考http://www.json.org/json-zh.html。同一个collection中,记录的格式可以是完全不通的,如:{name:"huaying", note:{phone_no:1234567, addr:"zhongguancun"}} 可以与{a:11}存放 在同一个collection内。

2)查找

> db.foo.find() 查询所有记录

> db.foo.findOne()查询一条记录

> db.foo.find(condition) 查询满足条件的所有记录

> db.foo.findOne(condition)查询满足条件的一条记录

condition也是以JSON形式给出的

3)删除

> db.foo.remove()删除所有记录

> db.foo.remove(condition)删除满足条件的记录

更详细的操作请参考:

3、 python driver

先安装pymongo,在python脚本中import pymongo

1)安装setuptools

# yum search setuptools

# yum install python-setuptools.noarch

# easy_install pymongo

2)使用方法

以一个python脚本为例来说明如何使用

test.py

###########################################

#!/usr/bin/env python

import datetime

from pymongo import Connection

#创建连接

cOnnection= Connection()

#创建database

db = connection.foo

#定义一条记录

post = {"author":"Mike",

        "text":"My first blog post!",

        "tags":["mongodb", "python", "python"],

        "data": datetime.datetime.utcnow()}

#创建collection

posts = db.posts

#将记录插到collection中

posts.insert(post)

#列出当前database中所有collection

data = db.collection_names()

print data

#列出一条记录

data = posts.find_one()

print data

#########################################

以上只是MongoDB的简单使用,数据库的关键是schema的设计。NOSQL目前大规模成功的应用还不多,使用风险比较大,可以作为Mysql的补充在系统中使用


推荐阅读
  • 在哈佛大学商学院举行的Cyberposium大会上,专家们深入探讨了开源软件的崛起及其对企业市场的影响。会议指出,开源软件不仅为企业提供了新的增长机会,还促进了软件质量的提升和创新。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文探讨了在通过 API 端点调用时,使用猫鼬(Mongoose)的 findOne 方法总是返回 null 的问题,并提供了详细的解决方案和建议。 ... [详细]
  • 本文详细介绍了Python编程语言的学习路径,涵盖基础语法、常用组件、开发工具、数据库管理、Web服务开发、大数据分析、人工智能、爬虫开发及办公自动化等多个方向。通过系统化的学习计划,帮助初学者快速掌握Python的核心技能。 ... [详细]
  • MongoDB的核心特性与架构解析
    本文深入探讨了MongoDB的核心特性,包括其强大的查询语言、灵活的文档模型以及高效的索引机制。此外,还详细介绍了MongoDB的体系结构,解释了其文档、集合和数据库的层次关系,并对比了MongoDB与传统关系型数据库(如MySQL)的逻辑结构。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 探讨如何高效使用FastJSON进行JSON数据解析,特别是从复杂嵌套结构中提取特定字段值的方法。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 在Ubuntu 16.04 LTS上配置Qt Creator开发环境
    本文详细介绍了如何在Ubuntu 16.04 LTS系统中安装和配置Qt Creator,涵盖了从下载到安装的全过程,并提供了常见问题的解决方案。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
author-avatar
创办m觉e内能h行宫
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有