Mongodb-- python中使用pymongo連接mongodb數據庫


一.使用

通過pip或者pychrm下載pymongo模塊

import json

from pymongo import MongoClient
from bson import ObjectId

mc = MongoClient("127.0.0.1",27017)
MONGODB = mc["數據庫名"]

MONGODB.users.find({}) # 可以操作了

上面的文件一般單獨寫一個settings.py,在用到的時候,通過引入MONGO來操作

關於bson:

  mongo中取出的數據有一個'_id'字段相當於mysql中的id, 這個字段的類型是Objectid,所以查詢的結果不能直接json序列化,需要將這個'_id'轉化為str類型后才能json序列化,相應的,從前端傳過來的'_id'也要通過bson轉化為ObjectId才能查到Mongodb中的數據

@au.route('/auto_login',methods=['POST'])
def auto_login():
    user_info = request.form.to_dict()
    print(user_info)

    try:
        user_id = user_info.get('user_id')
        user = MONGODB.users.find_one({'_id': ObjectId(user_id)}) user['_id'] = str(user['_id'])
        RET = {
            'code': 1,
            'msg': '自動登陸成功',
            'data': user
        }
    except:
        RET = {
            'code': 0,
            'msg': '自動登陸失敗',
            'data': {}
        }

    return jsonify(RET)

 

操作示例

# MONGODB = mc["admin"]
# res = MONGODB.users.find_one({"name":"Tom"})
# res["cours"].append({"name":"Tom","money":"100"})
# for index,cours in enumerate(res["cours"]):
#     if cours.get("name") == "Tom":
#         res["cours"][index]["score"] = 99


# MONGODB.users.delete_one({"age":84})
# MONGODB.users.delete_many({"age":84})

# user = MONGODB.users.find_one({"_id":ObjectId("5cb6eb7322b9441020186701")})
# print(user.get("_id"),type(user.get("_id")))
#
# user["_id"] = str(user["_id"])
# jsonstr = json.dumps(user)
# print(jsonstr , type(jsonstr))

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM