Python操作Mongodb資料庫

專注的阿熊發表於2021-04-29

1 、安裝 pymongo

# pip3 install pymongo

2 、操作 mongo 資料庫

import pymongo

client=pymongo.MongoClient("mongodb:// 使用者名稱 : 密碼 @ip:27017/")    # mongodb://admin:123456@192.168.221.128:27017

# 指定資料庫

db = client['albaba']

# 指定集合

collection = db['shops']

# 新增資料 , 欄位 :id 3394

collection.insert_one({"id": 3394})

# 查詢資料 find_one(),find()

result = collection.find_one({"id": 3394})

# 查詢一條 id 3394 的資訊

print(result)

# 查詢所有 category 欄位為果蔬生鮮 / 蔬菜的值

results = collection.find({"category": " 果蔬生鮮 / 蔬菜 "})

for one in results:

     print(one)

# 更新資料 , id=3394 的資料裡的 name 屬性值換成鮮花

collection.update_one(({"id": 3394}, {'$set': {'name': " 鮮花 "}}))

# 刪除資料 ,外匯跟單gendan5.com 刪除一條 id 3394 的資料

collection.delete_one({'id': 3394})

# 刪除資料 , 刪除所有 category 欄位值為果蔬生鮮 / 蔬菜

collection.delete_many({"category": " 果蔬生鮮 / 蔬菜 "})

3 、可以封裝成類,和對應的方法

import pymongo

class MongoDB:

     def __init__(self, user='admin', pwd='123456', ip='1192.168.221.128', port=27017):

         '''

         :param user: 使用者名稱

         :param pwd: 密碼

         :param ip: ip 地址

         :param port: 埠號

         '''

         self.user = user

         self.pwd=pwd

         self.ip=ip

         self.port=port

         self.client = pymongo.MongoClient(f"mongodb://{user}: {pwd}@{ip}:{port}/")

     def insert(self, collection, query, db='albaba'):

         '''

         :param db: 使用的資料庫

         :param collection: 使用的集合

         :param query: 新增的資訊

         :return:

         '''

         db = self.client[db]

         collection = db[collection]

         collection.insert_one(query)

     def find_one(self, collection, query, db='albaba'):

         '''

         :param db: 使用的資料庫

         :param collection: 使用的集合

         :param query: 查詢的資訊

         :return: 查詢結果

         '''

         db = self.client[db]

         collection = db[collection]

         result = collection.find_one(query)

         return result

     def find_all(self, collection, query, db='albaba'):

         '''

         :param db: 使用的資料庫

         :param collection: 使用的集合

         :param query: 查詢的資訊

         :return: 查詢返回所有結果

         '''

         db = self.client[db]

         collection = db[collection]

         results = collection.find(query)

         return results

     def update_one(self, collection, myquery, newvalues, db='albaba'):

         '''

         :param db: 使用的資料庫

         :param collection: 使用的集合

         :param myquery: 查詢的資訊

         :param newvalues: 修改的資訊

         :return:

         '''

         db=self.client[db]

         collection = db[collection]

         collection.update_one(myquery, {'$set': newvalues})

     def delete_one(self, collection, query, db='albaba'):

         '''

         :param db: 使用資料庫

         :param collection: 使用的集合

         :param query: 資訊

         :return:

         '''

         db = self.client[db]

         collection = db[collection]

         collection.delete_one(query)

     def delete_all(self, collection, query, db='albaba'):

         '''

         :param db: 使用資料庫

         :param collection: 使用的集合

         :param

         query: 資訊

         :return:

         '''

         db = self.client[db]

         collection = db[collection]

         collection.delete_many(query)

if __name__ == '__main__':

     db = MongoDB()

     res = db.find_one('albaba', 'shops', {'phone': '13500000822'})

     print(res)

     db.update_one('albaba', 'shops', {'phone': '13500000822'}, {'phone': '13500000833'})

     res1 = db.find_one('albaba', 'shops', {'id': 1})

     print(res1)


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69946337/viewspace-2770529/,如需轉載,請註明出處,否則將追究法律責任。

相關文章