`

mongodb基本知识

阅读更多
转载来自http://sha0k.iteye.com/blog/1375055

先去www.mongodb.org 下载,安装就直接解压到你就好了。
假设windows 32bit机,建立目录D:\mongodb   把压缩包bin目录下的exe全部放到mongodb目录下,然后建立一个data文件夹(D:\mongodb\data) 这个data目录就是用来存放数据的,默认是C盘data\db目录。
bin目录下的
mongod.exe - 数据库服务器.
mongo.exe - 管理员shell
当我们使用自定义的数据存储文件目录D:\mongodb\data时,使用cmd 进入D:\mongdodb目录
输入mongod --dbpath D:\mongodb\data用来启动时指定数据存储目录。
然后运行mongo.exe就行了。
使用help命令就可以查看所有想要得到的命令。

下面进入开发学习阶段:

其实我真的很想就复制粘贴官网的文档,因为真的很容易懂,都懒得翻译写出来了,唉。。。。。
启动之后,将看到
By default the shell connects to database "test" on localhost.  You then see:
Sql代码 
MongoDB shell version: <whatever> 
url: test 
connecting to: test 
type "help" for help 


"connecting to: " 显示了正在连接和使用的数据库。想要使用其它库, 键入:
Sql代码 
> use mydb 
switched to db mydb 

用use命令切换数据库并不能立即创建数据库,数据库将在第一次插入数据时延迟创建。可以使用show dbs查看数据库。
Inserting Data into A Collection
下面的shell命令,创建了两个对象j和t,并把它们存入sha0k集合中,K-V,就像map一样,称它集合,不为过吧。
Sql代码 
> j = { name : "mongo" }; 
{"name" : "mongo"} 
> t = { x : 3 }; 
{ "x" : 3  } 
> db.sha0k.save(j); 
> db.sha0k.save(t); 
> db.sha0k.find(); 
{ "_id" : ObjectId("4f2167ee......"), "name" : "mongo" } 
{ "_id" : ObjectId("4f2168f....."), "x" : 3 } 

对象Id太长了,我没写完,然后再使用show dbs就可以看到mydb已经在数据库列表中了,库创建完成。
有几点是需要注意的(我是真的懒得翻译了,见谅):
We did not predefine the collection. The database creates it automatically on the first insert.(没有预先定义集合)
The documents we store can have different fields - in fact in this example, the documents have no common data elements at all. In practice, one usually stores documents of the same structure within collections.()
Upon being inserted into the database, objects are assigned an object ID (if they do not already have one) in the field _id .
When you run the above example, your ObjectID values will be different.
一次添加多个对象:
Sql代码 
> for (var i = 1; i <= 20; i++) db.sha0k.save({x : 4, j : i}); 
> db.sha0k.find(); 
{ "_id" : ObjectId("4c2209f9f3924d31102bd84a"), "name" : "mongo" } 
{ "_id" : ObjectId("4c2209fef3924d31102bd84b"), "x" : 3 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd856"), "x" : 4, "j" : 1 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd857"), "x" : 4, "j" : 2 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd858"), "x" : 4, "j" : 3 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd859"), "x" : 4, "j" : 4 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85a"), "x" : 4, "j" : 5 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85b"), "x" : 4, "j" : 6 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85c"), "x" : 4, "j" : 7 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85d"), "x" : 4, "j" : 8 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85e"), "x" : 4, "j" : 9 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85f"), "x" : 4, "j" : 10 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd860"), "x" : 4, "j" : 11 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd861"), "x" : 4, "j" : 12 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd862"), "x" : 4, "j" : 13 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd863"), "x" : 4, "j" : 14 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd864"), "x" : 4, "j" : 15 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd865"), "x" : 4, "j" : 16 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd866"), "x" : 4, "j" : 17 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd867"), "x" : 4, "j" : 18 } 
has more 
我一共插入了20个数据,这里只显示了18个,并在下面提示has more,这是因为shell限制一个迭代的游标只到20,所以要查看下面的,需要使用it命令,iterator。。。。

Sql代码 
{ "_id" : ObjectId("4c220a42f3924d31102bd866"), "x" : 4, "j" : 17 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd867"), "x" : 4, "j" : 18 } 
has more 
> it 
{ "_id" : ObjectId("4c220a42f3924d31102bd868"), "x" : 4, "j" : 19 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd869"), "x" : 4, "j" : 20 } 

Accessing Data From a Query
有没有发现刚的办法很麻烦,20多个我就得打次it,40多个打两次,依次类推。。。。
有没有简单的办法呢,那就来看下面的,刚刚提到,mongodb 找到的数据指向都是游标。
Sql代码 
> var cursor = db.sha0k.find(); 
> while (cursor.hasNext()) printjson(cursor.next()); 
{ "_id" : ObjectId("4c2209f9f3924d31102bd84a"), "name" : "mongo" } 
{ "_id" : ObjectId("4c2209fef3924d31102bd84b"), "x" : 3 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd856"), "x" : 4, "j" : 1 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd857"), "x" : 4, "j" : 2 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd858"), "x" : 4, "j" : 3 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd859"), "x" : 4, "j" : 4 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85a"), "x" : 4, "j" : 5 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85b"), "x" : 4, "j" : 6 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85c"), "x" : 4, "j" : 7 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85d"), "x" : 4, "j" : 8 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85e"), "x" : 4, "j" : 9 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85f"), "x" : 4, "j" : 10 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd860"), "x" : 4, "j" : 11 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd861"), "x" : 4, "j" : 12 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd862"), "x" : 4, "j" : 13 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd863"), "x" : 4, "j" : 14 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd864"), "x" : 4, "j" : 15 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd865"), "x" : 4, "j" : 16 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd866"), "x" : 4, "j" : 17 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd867"), "x" : 4, "j" : 18 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd868"), "x" : 4, "j" : 19 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd869"), "x" : 4, "j" : 20 } 
第二行的printjson()函数,可以从环境中理解出来,就是将对象以json数据格式打印出来,上面的例子是游标风格的迭代。
Sql代码 
> var cursor = db.sha0k.find(); 
> printjson(cursor[4]); 
{ "_id" : ObjectId("4c220a42f3924d31102bd858"), "x" : 4, "j" : 3 } 
When using a cursor this way, note that all values up to the highest accessed (cursor[4] above) are loaded into RAM at the same time. This is inappropriate for large result sets, as you will run out of memory. Cursors should be used as an iterator with any query which returns a large number of elements.(请注意内存溢出)
  数组访问方式:
Sql代码 
> var arr = db.sha0k.find().toArray(); 
> arr[5]; 
{ "_id" : ObjectId("4c220a42f3924d31102bd859"), "x" : 4, "j" : 4 } 

Specifying What the Query Returns
    SELECT * FROM things WHERE x=4
Sql代码 
> db.sha0k.find({x:4}).forEach(printjson); 
{ "_id" : ObjectId("4c220a42f3924d31102bd856"), "x" : 4, "j" : 1 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd857"), "x" : 4, "j" : 2 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd858"), "x" : 4, "j" : 3 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd859"), "x" : 4, "j" : 4 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85a"), "x" : 4, "j" : 5 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85b"), "x" : 4, "j" : 6 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85c"), "x" : 4, "j" : 7 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85d"), "x" : 4, "j" : 8 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85e"), "x" : 4, "j" : 9 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85f"), "x" : 4, "j" : 10 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd860"), "x" : 4, "j" : 11 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd861"), "x" : 4, "j" : 12 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd862"), "x" : 4, "j" : 13 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd863"), "x" : 4, "j" : 14 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd864"), "x" : 4, "j" : 15 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd865"), "x" : 4, "j" : 16 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd866"), "x" : 4, "j" : 17 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd867"), "x" : 4, "j" : 18 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd868"), "x" : 4, "j" : 19 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd869"), "x" : 4, "j" : 20 } 
   A query document of the form { a:A, b:B, ... } means "where a==A and b==B and ...".

使用true关键字,只查找j的值结果集
SELECT j FROM things WHERE x=4
Sql代码 
> db.sha0k.find({x:4}, {j:true}).forEach(printjson); 
{ "_id" : ObjectId("4c220a42f3924d31102bd856"), "j" : 1 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd857"), "j" : 2 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd858"), "j" : 3 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd859"), "j" : 4 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85a"), "j" : 5 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85b"), "j" : 6 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85c"), "j" : 7 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85d"), "j" : 8 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85e"), "j" : 9 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd85f"), "j" : 10 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd860"), "j" : 11 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd861"), "j" : 12 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd862"), "j" : 13 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd863"), "j" : 14 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd864"), "j" : 15 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd865"), "j" : 16 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd866"), "j" : 17 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd867"), "j" : 18 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd868"), "j" : 19 } 
{ "_id" : ObjectId("4c220a42f3924d31102bd869"), "j" : 20 } 


都是记录学习,thx
分享到:
评论
1 楼 like_shadows 2012-04-23  
真不错,顶
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    MongoDB若基本操作

    在这个“MongoDB基本操作”的主题中,我们将深入探讨如何使用MongoDB进行数据的增删改查以及其它关键操作。 1. **安装与启动MongoDB** - 在不同的操作系统(如Windows、Linux或macOS)上安装MongoDB的步骤略有不同...

    Mongodb基础知识详解(值得珍藏).pdf

    总的来说,掌握MongoDB的基础知识对于开发人员来说至关重要,无论是理解数据模型、提高查询效率,还是构建可扩展和可靠的应用程序,MongoDB都提供了强大的工具和支持。通过深入学习和实践,开发者可以充分利用...

    mongodb实验-数据库基本操作-MongoDB数据库基本操作指南:连接、创建与CRUD实验

    使用场景及目标:帮助读者快速掌握MongoDB基本操作,能够在实际工作中熟练运用数据库的创建、数据管理等技能。 阅读建议:在阅读时建议边学边做,实际操作每一步骤,通过动手实验巩固理论知识,加强对MongoDB操作的...

    mongodb 数据库基本操作

    对于工作1-3年的运维人员来说,掌握MongoDB的基本操作是提升工作效率的重要一环。下面我们将详细介绍MongoDB数据库的基本操作。 1. 安装与启动MongoDB: 在不同的操作系统上,安装MongoDB的步骤略有不同。通常,你...

    mongodb入门

    本书《mongodb入门》是一本旨在帮助初学者快速学习MongoDB基本用法的入门小书。它适合那些希望在短时间内掌握MongoDB核心概念和操作的读者。作者Karl Seguin是一位拥有丰富技术背景的开发者,其经历跨越多个领域和...

    五、MongoDB 学习PPT

    MongoDB 是一种流行的开源NoSQL数据库,以其面向文档的数据模型、高性能、高可用性和高可扩展性而闻名...无论是初学者还是经验丰富的开发者,都需要掌握MongoDB的基础知识和操作技巧,以便在实际项目中充分利用其优势。

    php+mvc+mongodb数据库基本操作

    现在我们来详细探讨这些知识点。 首先,PHP的MVC架构是一种将业务逻辑、数据和用户界面分离的设计模式。在MVC模式中: - **Model**(模型):负责处理应用程序的数据和业务逻辑,它与数据库交互,获取和存储数据。...

    mongodb资料

    1. **mongodb快速入门-基本操作.doc**:这份文档可能介绍了MongoDB的基本概念,如数据库、集合、文档,以及插入、查询、更新和删除数据的基本命令。 2. **php操作mongodb和mongodb的权限机制.doc**:这个文档应该...

    MongoDB 权威指南.pdf

    #### 二、MongoDB基本概念 1. **文档(Document)**:MongoDB中最小的数据单位,相当于关系型数据库中的行。文档由一系列键值对组成,每个键对应一个值,值可以是任何有效的JSON数据类型。 2. **集合(Collection)...

    MongoDB4.2.21 Linux版本安装包

    本篇将详细介绍在Linux上安装MongoDB 4.2.21的步骤,以及相关的知识点。 首先,我们需要了解MongoDB的体系结构。MongoDB由以下几个核心组件构成: 1. **Mongod**:这是MongoDB的主要服务进程,负责处理所有数据库...

    MongoDB with F#

    1. **MongoDB 的基本概念** 2. **F# 语言特性及其在 MongoDB 应用中的优势** 3. **使用 C# 驱动器操作 MongoDB 的方法** 4. **利用 F# 的类型系统改进 MongoDB 中字符串泛滥的问题** #### MongoDB 基本概念 MongoDB...

    MongoDB基本查询1.pdf

    以上都是MongoDB中进行基本查询的关键知识点,涵盖了查询所有文档、特定条件查询、排除特定字段、选择返回字段、范围查询以及不等于查询等。熟悉这些操作对于有效地管理MongoDB数据库至关重要。在实际应用中,根据...

    mongodb 数据库基本操作.docx

    ### MongoDB 数据库基本操作知识点详解 #### 一、MongoDB 安装与配置 ##### 1. 下载 MongoDB - **官网访问**:首先访问 MongoDB 官方网站。 - **选择版本**:根据你的操作系统(如 Windows、Linux 或 macOS)选择...

    MongoDB Days 2015 深圳 PPT 共享

    8. **性能调优**: 除了基本的查询优化,还包括内存管理、磁盘I/O优化、数据模型设计等方面的知识,这些都是确保MongoDB高效运行的重要因素。 9. **安全与认证**: MongoDB的安全特性包括用户认证、访问控制、SSL加密...

    MongoDB测试二题目及答案.doc

    下面是MongoDB测试二题目及答案的知识点总结: 1. 创建数据库和集合:在MongoDB中,创建数据库和集合是通过db.createCollection()方法实现的。例如,创建一个名为mydb的数据库和一个名为students的集合,可以使用db...

    mongodb实验-数据库基本操作-MongoDB实验:数据库基本操作指南与实例

    ②学会在MongoDB中创建数据库、集合并进行基本的数据操作;③熟悉MongoDB的索引管理;④能够通过具体的实例练习提高实践能力。 阅读建议:跟随文章提供的实验步骤进行实际操作,在实践中加深理解。同时可以查阅更多...

    mongodb-基础知识和高级知识

    这个资料包包含了“mongodb_base.pdf”和“mongodb_advance.pdf”两个文件,分别涵盖了MongoDB的基础知识和高级知识。 首先,让我们从基础开始。MongoDB的基础知识主要包括以下几个方面: 1. 数据模型:MongoDB...

    java连接mongodb的jar包

    在本文中,我们将深入探讨如何使用Java连接MongoDB,涉及的知识点包括MongoDB Java驱动程序的安装、配置,以及基本的连接和操作数据库的方法。 首先,我们来看“java连接mongodb的jar包”。这个“mongodbjar”通常...

    mongodb安装包

    五、MongoDB基本配置 在安装完成后,需要对mongod.conf配置文件进行适当的调整,如设置端口号(默认27017)、日志文件位置、数据存储路径等。 六、MongoDB启动与停止 1. Windows:通过服务管理器启动或停止MongoDB...

Global site tag (gtag.js) - Google Analytics