mongoDB Shell:
启动mongoDB shell(我已经把mongodb\bin加入path环境变量):mongo
由于Mongo是个javaScript Shell,通过在线查看JavaScript的文档能获得更多帮助。shell本身内置了帮助文档,可以通过help命令查看
创建数据库(MongoDB use DATABASE_NAME):
use DATABASE_NAME
查看所有数据库:
show dbs local 0.78125GB test 0.23012GB注意:这里是看不到刚刚创建的数据库的,如果想要看见,必须插入至少一个文件
切换数据库:use dbName
删除数据库:MongoDB db.dropDatabase()
注意:需要先use切换至需要删除的数据库
创建集合:MongoDB db.createCollection(name, options)
两个参数说明:
参数 | 类型 | 描述 |
---|---|---|
Name | String | 要创建的集合名称 |
Options | Document | (可选)指定有关内存大小和索引选项 |
字段 | 类型 | 描述 |
---|---|---|
capped | Boolean | (可选)如果为true,则启用封顶集合。封顶集合是固定大小的集合,会自动覆盖最早的条目,当它达到其最大大小。如果指定true,则需要也指定尺寸参数。 |
autoIndexID | Boolean | (可选)如果为true,自动创建索引_id字段的默认值是false。 |
size | number | (可选)指定最大大小字节封顶集合。如果封顶如果是 true,那么你还需要指定这个字段。 |
max | number | (可选)指定封顶集合允许在文件的最大数量。 |
示例:
1:创建只有必选参数的集合
db.createCollection("mycollection")2:创建带有option参数的集合:
db.createCollection("mycol", { capped : true, autoIndexID : true, size : 6142800, max : 10000 } )3:当然也不必非要用createCollection创建,当插入一些文件MongoDB会自动创建集合:
>db.zidong.insert({"name" : "ding"}) >show collections mycol mycollection system.indexes yiibai
查看所有集合:show collections
删除集合:MongoDB db.collectionName.drop()
说明:drop() 方法将返回 true,如果选择成功收集被丢弃,否则将返回 false
数据类型:
String : 这是最常用的数据类型来存储数据。在MongoDB中的字符串必须是有效的UTF-8。
Integer : 这种类型是用来存储一个数值。整数可以是32位或64位,这取决于您的服务器。
Boolean : 此类型用于存储一个布尔值 (true/ false) 。
Double : 这种类型是用来存储浮点值。
Min/ Max keys : 这种类型被用来对BSON元素的最低和最高值比较。
Arrays : 使用此类型的数组或列表或多个值存储到一个键。
Timestamp : 时间戳。这可以方便记录时的文件已被修改或添加。
Object : 此数据类型用于嵌入式的文件。
Null : 这种类型是用来存储一个Null值。
Symbol : 此数据类型用于字符串相同,但它通常是保留给特定符号类型的语言使用。
Date : 此数据类型用于存储当前日期或时间的UNIX时间格式。可以指定自己的日期和时间,日期和年,月,日到创建对象。
Object ID : 此数据类型用于存储文档的ID。
Binary data : 此数据类型用于存储二进制数据。
Code : 此数据类型用于存储到文档中的JavaScript代码。
Regular expression : 此数据类型用于存储正则表达式
插入文档:insert() 或 save() 方法
这里 mycol 是集合的名称,如前面的教程中创建。如果集合在数据库中不存在,那么MongoDB 将创建此集合,然后把它插入文档。
插入文档中,如果我们不指定_id参数,然后MongoDB 本文档分配一个独特的ObjectId。
_id 是12个字节的十六进制数,唯一一个集合中的每个文档。 12个字节被划分如下:
_id: ObjectId(4 bytes timestamp, 3 bytes machine id, 2 bytes process id, 3 bytes incrementer)要插入单个查询的多个文档,可以传递一个文档数组 给insert() 命令。
查询文档: find()
find() 方法将在非结构化的方式显示所有的文件。
结果显示在一个格式化的方式,可以使用 pretty() 方法.
>db.mycol.find().pretty() { "_id": ObjectId(7df78ad8902c), "title": "MongoDB Overview", "description": "MongoDB is no sql database", "by": "tutorials point", "url": "http://www.yiibai.com", "tags": ["mongodb", "database", "NoSQL"], "likes": "100" } >
除了find() 方法外,还有一个 findOne() 法,返回一个文件。
要查询文件的一些条件的基础上,可以使用下面的操作
操作 | 语法 | 例子 | RDBMS 等同 |
---|---|---|---|
Equality | {<key>:<value>} | db.mycol.find({"by":"tutorials point"}).pretty() | where by = 'tutorials point' |
Less Than | {<key>:{$lt:<value>}} | db.mycol.find({"likes":{$lt:50}}).pretty() | where likes < 50 |
Less Than Equals | {<key>:{$lte:<value>}} | db.mycol.find({"likes":{$lte:50}}).pretty() | where likes <= 50 |
Greater Than | {<key>:{$gt:<value>}} | db.mycol.find({"likes":{$gt:50}}).pretty() | where likes > 50 |
Greater Than Equals | {<key>:{$gte:<value>}} | db.mycol.find({"likes":{$gte:50}}).pretty() | where likes >= 50 |
Not Equals | {<key>:{$ne:<value>}} | db.mycol.find({"likes":{$ne:50}}).pretty() | where likes != 50 |