• pymongo 常用方法


    setting设置

    STORAGE = {
      # 远程服务器地址
    # 'MONGODB': {'host': '47.98.100.240', 'port': 27017},
    # 本地mongo测试地址
    'MONGODB': {'host': '192.168.0.190', 'port': 27017},

        # 本地redis测试地址
      'REDIS_CONTENT': {'host': '192.168.0.190', 'port': 6379, 'db': 0},
    }
    # 项目使用的数据库
    DATABASE_CONTENT = "dbname"

    models设置

    import pymongo
    import redis
    import settings

    mongo_client = pymongo.MongoClient(**settings.STORAGE['MONGODB'])
    db = mongo_client[settings.DATABASE_CONTENT]

    增加新文档:

    models.db.collectionname1.insert_one(con_dict)  # con_dict 为组织好数据格式的字典

    对查询结果集排序:
    models.db.collectionname1.find({}).sort("updated_at",pymongo.DESCENDING) # 倒叙排列
    
    
    更新满足条件的字段字段find:

    models.db.collectionname1.find_one({"rank_id": 1}).get("content_id")


    条件查询id在已知的列表(recommend_list=[1,2,5]):
    models.db.collectionname1.find({"id": {"$in": recommend_list}})

    正则匹配名称,不区分大小写,结果不展示 "_id"字典
    models.db.collectionname.find({"name":{"$regex":content_name, "$options":'i'}}, {"_id": 0})
    查询字段不等于1的数据
    models.db.collectionname.find({"status":{"$ne":1}})
    查询集结果的数目:
    models.db.collectionname.count()
    
    

    更新满足条件的字段字段update
    models.db.collectionname.update({"rank_id":1},{"$pullAll":{"content_id":del_list}})

    db.test0.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } ); 只更新了第一条记录
    db.test0.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true ); 全更新了
    db.test0.update( { "count" : { $gt : 4 } } , { $set : { "test5" : "OK"} },true,false ); 只加进去了第一条
    db.test0.update( { "count" : { $gt : 5 } } , { $set : { "test5" : "OK"} },true,true ); 全加进去了
    db.test0.update( { "count" : { $gt : 15 } } , { $inc : { "count" : 1} },false,true );全更新了
    db.test0.update( { "count" : { $gt : 10 } } , { $inc : { "count" : 1} },false,false );只更新了第一条

    1) $inc

    用法:{ $inc : { field : value } }

    意思对一个数字字段field增加value,例:

    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 16, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

    > db.test0.update( { "_id" : 15 } , { $inc : { "count" : 1 } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 17, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

    > db.test0.update( { "_id" : 15 } , { $inc : { "count" : 2 } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 19, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

    > db.test0.update( { "_id" : 15 } , { $inc : { "count" : -1 } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

    2) $set

    用法:{ $set : { field : value } }

    就是相当于sql的set field = value,全部数据类型都支持$set。例:
    > db.test0.update( { "_id" : 15 } , { $set : { "test1" : "testv1","test2" : "testv2","test3" : "testv3","test4" : "testv4" } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : "testv1", "test2" : "testv2", "test3" : "testv3", "test4" : "testv4", "test5" : "OK" }
    3) $unset

    用法:{ $unset : { field : 1} }

    顾名思义,就是删除字段了。例:
    > db.test0.update( { "_id" : 15 } , { $unset : { "test1":1 } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test2" : "testv2", "test3" : "testv3", "test4" : "testv4", "test5" : "OK" }

    > db.test0.update( { "_id" : 15 } , { $unset : { "test2": 0 } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test3" : "testv3", "test4" : "testv4", "test5" : "OK" }

    > db.test0.update( { "_id" : 15 } , { $unset : { "test3":asdfasf } } );
    Fri May 14 16:17:38 JS Error: ReferenceError: asdfasf is not defined (shell):0

    > db.test0.update( { "_id" : 15 } , { $unset : { "test3":"test" } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test4" : "testv4", "test5" : "OK" }

    没看出field : 1里面的1是干什么用的,反正只要有东西就行。

    4) $push
    用法:{ $push : { field : value } }
    
    把value追加到field里面去,field一定要是数组类型才行,如果field不存在,会新增一个数组类型加进去。例:
    
    > db.test0.update( { "_id" : 15 } , { $set : { "test1" : ["aaa","bbb"] } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb" ], "test4" : "testv4", "test5" : "OK" }
    
    > db.test0.update( { "_id" : 15 } , { $push : { "test1": "ccc" } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc" ], "test4" : "testv4", "test5" : "OK" }
    
    > db.test0.update( { "_id" : 15 } , { $push : { "test2": "ccc" } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc" ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
    
    > db.test0.update( { "_id" : 15 } , { $push : { "test1": ["ddd","eee"] } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

    5) $pushAll

    用法:{ $pushAll : { field : value_array } }

    同$push,只是一次可以追加多个值到一个数组字段内。例:

    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

    > db.test0.update( { "_id" : 15 } , { $pushAll : { "test1": ["fff","ggg"] } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ], "fff", "ggg" ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

    6)  $addToSet

    用法:{ $addToSet : { field : value } }
    
    增加一个值到数组内,而且只有当这个值不在数组内才增加。例:
    > db.test0.update( { "_id" : 15 } , { $addToSet : { "test1": {$each : ["444","555"] } } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
            "aaa",
            "bbb",
            "ccc",
            [
                    "ddd",
                    "eee"
            ],
            "fff",
            "ggg",
            [
                    "111",
                    "222"
            ],
            "444",
            "555"
    ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
    > db.test0.update( { "_id" : 15 } , { $addToSet : { "test1": {$each : ["444","555"] } } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
            "aaa",
            "bbb",
            "ccc",
            [
                    "ddd",
                    "eee"
            ],
            "fff",
            "ggg",
            [
                    "111",
                    "222"
            ],
            "444",
            "555"
    ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
    > db.test0.update( { "_id" : 15 } , { $addToSet : { "test1": ["444","555"]  } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
            "aaa",
            "bbb",
            "ccc",
            [
                    "ddd",
                    "eee"
            ],
            "fff",
            "ggg",
            [
                    "111",
                    "222"
            ],
            "444",
            "555",
            [
                    "444",
                    "555"
            ]
    ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
    > db.test0.update( { "_id" : 15 } , { $addToSet : { "test1": ["444","555"]  } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
            "aaa",
            "bbb",
            "ccc",
            [
                    "ddd",
                    "eee"
            ],
            "fff",
            "ggg",
            [
                    "111",
                    "222"
            ],
            "444",
            "555",
            [
                    "444",
                    "555"
            ]
    ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
    
    
    7) $pop
    
    删除数组内的一个值
    
    用法:
    删除最后一个值:{ $pop : { field : 1  } }
    删除第一个值:{ $pop : { field : -1  } }
    
    注意,只能删除一个值,也就是说只能用1或-1,而不能用2或-2来删除两条。mongodb 1.1及以后的版本才可以用,例:
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
            "bbb",
            "ccc",
            [
                    "ddd",
                    "eee"
            ],
            "fff",
            "ggg",
            [
                    "111",
                    "222"
            ],
            "444"
    ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
    > db.test0.update( { "_id" : 15 } , { $pop : { "test1": -1 } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
            "ccc",
            [
                    "ddd",
                    "eee"
            ],
            "fff",
            "ggg",
            [
                    "111",
                    "222"
            ],
            "444"
    ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
    > db.test0.update( { "_id" : 15 } , { $pop : { "test1": 1 } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", "ggg", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4",
    "test5" : "OK" }
    
    8) $pull
    
    用法:$pull : { field : value } }
    
    从数组field内删除一个等于value值。例:
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", "ggg", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4",
    "test5" : "OK" }
    
    > db.test0.update( { "_id" : 15 } , { $pull : { "test1": "ggg" } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5"
     : "OK" }
    
    9) $pullAll
    
    用法:{ $pullAll : { field : value_array } }
    
    同$pull,可以一次删除数组内的多个值。例:
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5"
     : "OK" }
    
    > db.test0.update( { "_id" : 15 } , { $pullAll : { "test1": [ "ccc" , "fff" ] } } );
    > db.test0.find( { "_id" : 15 } );
    { "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ [ "ddd", "eee" ], [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

  • 相关阅读:
    HttpContext.GetOwinContext().Authentication 报错 解决办法
    owin Claims-based认证登录实现
    angularjs初识ng-app、ng-model、ng-repeat指令
    SpringBoot配置slf4j logback-spring.xml日志
    idea时间注释模版
    oracel截取字符串
    win10官网下载地址
    使用HttpWebRequest实现basic身份认证
    mybatis常用jdbcType数据类型与mysql的类型对照
    修改IntelliJ IDEA 默认配置路径
  • 原文地址:https://www.cnblogs.com/maxiaohei/p/8127566.html
Copyright © 2020-2023  润新知