mongodb常用的操作

帮助help

 help -----帮助
 db.help() 
        -----显示当前文档的方法
 db.test.help()             
        -----显示数据库下test集合(document\表)所有
 使用的方法
 db.test.find().help()  
        -----显示当前数据下test集合的所有数据方法
 db 显示当前数据名称        
        -----首次进入时 默认为test

创建、切换数据库

    use movie               -----切换 创建数据库 (有点话是创建、没有的时候回创建)
                            -----首次创建的数据库不会显示 应为内容为空 
    db.createCollection("a")   -----创建文档(表) 此时就可以在可视化工具中看到数据库
    db.createCollection("a",{size:20,capped:true,max:200})   -----创建文档 不建议
    show dbs                -----显示数据库列表    
    show collections        -----获取集合列表
    db.stats()              -----显示当前数据库的状态(信息)
    db.version()            -----显示当前数据库的版本信息
    db.getMongo()           -----获取当前数据库连接的服务器信息
        connection to 127.0.0.1:27017
    
    db.getName()            -----获取当前数据库的名称,相当于db
    db.dropDatabase()       -----删除当前数据库    小bug删除后使用db还是显示原数据库名称
    db.collection.drop()    -----删除集合
    
    db.getCollection("collName");       ------得到指定名称的聚集集合
    db.getCollectionNames();            ------得到当前DB的所有的聚集集合   以数组的形式
    db.printCollectionStats();          ------显示当前db所有集合的状态

    1.插入文档
        db.ele.insert({name:1,age:20,sex:"man"})            ------插入以对象的方式
        db.ele.save({name:2,age:20,sex:"women"})
        db.ele.insertOne({name:20,age:0})                   ------单次插入
        db.ele.insertMany([{},{}])                          ------插入多个文档,以数组存储对象的方式 

    remove({},false,err)
        一个参数为匹配条件
        第二个参数为是否只删除第一个  默认false 全部删除  设置为true时 只删除第一个匹配的(也可以设置为1)
        第三个为抛出的异常
    
        db.ele.remove({name:"tehui"})
            -----会删除匹配到的多个文档
        db.ele.remove({name:"tehui"},true)
            -----只删除了第一个匹配的
        db.ele.deleteMany({"business_flag":2})
            ------删除多个文档时可用,删除一个时也可用

    updatae({},{},true,false)
        4个参数  第一个是匹配的条件
                第二个更新的属性
                第三参数 匹配不到时 是否插入 默认为false 不插入
                第四个参数   是否只跟新第一个匹配到的文档  默认false 只更新第一次匹配到的文档

        更新business_flag为14的数据,使它name=新店特惠1
            db.ele.update({"business_flag":14},{$set:{name:"tehui"}})
                -----WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
                -----匹配到1个 更新1个
            
            db.ele.update({"business_flag":24},{$set:{name:"tehui"}},false)
            db.ele.update({"business_flag":24},{$set:{name:"tehui"}})               
                ----第三个参数为false时 和默认时
                ----WriteResult({ "nMatched" : 0, "nUpserted" : 0, "nModified" : 0 })
            db.ele.update({"business_flag":24},{$set:{name:"tehui"}},true)
                ----第三个参数为true时
                ----WriteResult({
                        "nMatched" : 0,
                        "nUpserted" : 1,
                        "nModified" : 0,
                        "_id" : ObjectId("59662b20e6c44cb771e9e3dc")})
        
        
        db.ele.update({"is_in_serving":true},{$set:{name:"111"}},false,false)
                ----第四个参数为默认值和false时 只匹配了第一个
        db.ele.update({"is_in_serving":true},{$set:{name:"111"}},false,true)
                ----设置为true 是所有满足条件的都匹配 和更新
        
        当匹配的文档没有改字段时添加字段
            db.ele.update({},{$inc:{business_flag:1}},false,true)

find    第一个参数是限制条件      {}对象 空的时候表示没有限制,会匹配所有  键值对  其中值也可以为对象
        第二个是显示的格式       {}对象 键值对值为0时不显示 1为显示  不设置是默认全显示

    简单的查询:
        db.ele.find({})        ------查询结果是没有使用任何符号相连接的,
                                    每一个对象又叫做一个document(文档----行)
        db.ele.find({},{name:1,_id:0}) 
        db.elelist.find({"name":"下午茶"})
            ----该方法会显示name为下午茶的集合的所有数据   体验不好       
        db.ele.find({name:"美食"},{name:1,_id:0})         
            ----查询条件 name:美食,显示name _id不显示      
    
    查询大于某一条件:
        db.ele.find({"business_flag":{$gt:5}},{_id:0,name:1})
            -----大于5的部分用对象实现,对象内部大于用$gt

    小于 {$lt:10}
        db.ele.find({"business_flag":{$lt:10}},{_id:0,name:1})
            ------小于10的部分
    
    大于等于{$gte:num}
        db.ele.find({"business_flag":{$gte:4}},{_id:0,name:1})
            -----$gt 后加e 改成$gte
    
    小于等于{$lte:num}
        db.ele.find({"business_flag":{$gte:4}},{_id:0,name:1})
    
    并且{obj1,obj2}
        db.ele.find({"business_flag":{$lt:16},id:{$gt:10}},{_id:0,name:1})
            ------第一参数设置两个属性 即设置两个条件
    
    查询num1~num2之间的数据{$gt:num,$lt:num1}
        db.ele.find({"business_flag":{$gt:6,$lt:14}},{_id:0,name:1})
            -------键值对 值也可以设成对象的形式。
    
    查询去重    distinct(独特性)
        db.ele.distinct("business_flag")
            -------即查询文档中 某一属性的值的种类
    
    模糊查询        //
        db.ele.find({name:/午/},{_id:0,name:1})
            //中的字符串不用加'' 加了会认为是匹配"午"而不是 午
            
    查询后的数据 排序  sort({"键":值}) 其中键表示按什么排序   值为1是升序  值为-1是为降序
        db.ele.find({},{"business_flag":1,"name":1,_id:0}).sort({"business_flag":1});  
             ---升序
        db.ele.find({},{"business_flag":1,"name":1,_id:0}).sort({"business_flag":-1}); 
              ---升序
        
    查询前num条     limit(num)
        db.ele.find({},{_id:0,name:1,"business_flag":1}).limit(5)
            -----查询前5条 包括第5条
    
    查询index后的数据  skip(num)  
        db.ele.find({},{_id:0,name:1,business_flag:1}).skip(6)
            -------查询第7条开始后的数据
    
    查询a~b之间的数据
        db.ele.find({},{_id:0,name:1,business_flag:1}).limit(5).skip(6)
            其实相当于查询第6条之后的5个信息 不包括第6条信息
    
    查询匹配条件的文档集的数
        db.ele.find({"business_flag":{$lt:14}},{_id:0,name:1,business_flag:1}).count()
            ----------输出的结果是匹配的数目
    
    匹配含有某一条件的集合的数目
        db.ele.find({"business_flag":{$exists:true}}).count()
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,050评论 25 707
  • 需要原文的可以留下邮箱我给你发,这里的文章少了很多图,懒得网上粘啦 1数据库基础 1.1数据库定义 1)数据库(D...
    极简纯粹_阅读 7,421评论 0 46
  • 郭相麟 一位八零后创业家写给家人的忏悔信 亲爱的老婆,孩子: 你们好!提笔在手,内心百感交集,为了成就事业梦想...
    郭相麟阅读 206评论 0 0
  • 工作模式与连接数上限 设定http服务器 #FastCGI相关参数是为了改善网站的性能:减少资源占用,提高访问速度...
    layjoy阅读 2,603评论 0 5
  • 文/ 雨清泽 张爱玲《流言》。之前一直在读她的小说,没有想到一个小说家的散文,也写得这样流畅。她的散文不美,没有在...
    雨清泽阅读 3,224评论 11 103