时间:2021-07-01 10:21:17 帮助过:12人阅读
> show dbs; admin 0.000GB local 0.000GB > use testdb; switched to db testdb > post={"title":"My Blog Post", ... "content":"HaHa", ... "date":new Date()} { "title" : "My Blog Post", "content" : "HaHa", "date" : ISODate("2017-07-07T03:20:44.698Z") } > db.blog.insert(post) WriteResult({ "nInserted" : 1 }) > db.blog.find() { "_id" : ObjectId("595efe1af713ea7372854b9c"), "title" : "My Blog Post", "content" : "HaHa", "date" : ISODate("2017-07-07T03:20:44.698Z") }
2)读取: find和findOne方法用于查询集合里的文档,若只想看一个文档,可以用findOne,上面例子的查询 find查询的时候最多显示20个匹配的文档
> db.blog.findOne() { "_id" : ObjectId("595efe1af713ea7372854b9c"), "title" : "My Blog Post", "content" : "HaHa", "date" : ISODate("2017-07-07T03:20:44.698Z") }
3)更新: 使用update修改,update接受至少两个参数,第一个是限定条件(用于匹配待更新的文档),第二个是新的文档。假设,在刚刚的基础上,添加评论功能,使用数组存储
> post.comments=[] [ ] > db.blog.update({"_id":ObjectId("595efe1af713ea7372854b9c")},post) WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 }) > db.blog.findOne() { "_id" : ObjectId("595efe1af713ea7372854b9c"), "title" : "My Blog Post", "content" : "HaHa", "date" : ISODate("2017-07-07T03:20:44.698Z"), "comments" : [ ] }可以通过查询看到,已经添加了comments键 4)删除: 使用remove方法可将文档从数据库中永久的删除,如果没有使用参数匹配,那么则会删除集合内的所有文档。它可以接受一个作为限定条件的文档作为参数
> db.blog.remove({"_id":ObjectId("595efe1af713ea7372854b9c")}) WriteResult({ "nRemoved" : 1 }) > db.blog.findOne() null可以看到,集合内没有文档了 三:数据类型 null:用于表示空值或者不存在的字段 {"x":null} 布尔型:布尔型有两个值true和false {"x":true} 数值: shell默认使用64位浮点型数值 {"x":3.14} or {"x":3} 对于整型值,可使用NumberInt类(表示4字节带符号整数) {"x":NumberInt("3")} NumberLong类(表示8字节带符号整数) {"x":NumberLong("3")} 字符串:UTF-8字符串都可以表示为字符串类型的数据 {"x":"foobar"} 日期:日期被存储为自新世纪元以来经过的毫秒数,不存储时区 {"x":new Date} 正则表达式:查询时,使用正则表达式作为限定条件 {"x":/foobar/i} 数组:数据列表或数据集可以表示为数组 {"x":["a","b","c","d"]} 内嵌文档:文档可嵌套其他文档 {"x":{"foo":"bar"}} 对象id:对象id是一个12字节的ID,是文档的唯一标识 MongoDB shell的技巧: 在连接进入mongo后,可以使用help来帮助查看
> help db.help() help on db methods db.mycoll.help() help on collection methods sh.help() sharding helpers rs.help() replica set helpers help admin administrative help help connect connecting to a db help help keys key shortcuts help misc misc things to know help mr mapreduce show dbs show database names show collections show collections in current database show users show users in current database show profile show most recent system.profile entries with time >= 1ms show logs show the accessible logger names show log [name] prints out the last segment of log in memory, ‘global‘ is default use <db_name> set current database db.foo.find() list objects in collection foo db.foo.find( { a : 1 } ) list objects in foo where a == 1 it result of the last line evaluated; use to further iterate DBQuery.shellBatchSize = x set default number of items to display on shell exit quit the mongo shell查看一个函数的源代码,可以直接使用,如:db.test.update 就会把update函数给显示出来
MongoDB基础知识(二)
标签:第一个 name dynamic comment .com alt 64位 基本 match