黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

python連接、操作mongodb數據庫的方法實例詳解

系統 1980 0

本文實例講述了python連接、操作mongodb數據庫的方法。分享給大家供大家參考,具體如下:

數據庫連接

            
from pymongo import MongoClient
import pandas as pd
#建立MongoDB數據庫連接
client = MongoClient('162.23.167.36',27101)#或MongoClient("mongodb://162.23.167.36:27101/")
#連接所需數據庫,testDatabase為數據庫名:
db=client.testDatabase
#連接所用集合,也就是我們通常所說的表,testTable為表名
collection=db.testTable


          

查詢前幾條

            
dataSet=collection.find().limit(3)
for item in dataSet:
  print(item)


          

無條件查詢全部

            
dataSet=collection.find()
for item in dataSet:
  print(item)


          

按AND條件查詢全部

            
#查詢cpu使用率大于等于10且內存使用率大于等于10的所有字段數據
dataSet=collection.find({"cpu":{"$gte":10},"mem":{"$gte":10}})
for item in dataSet:
  print(item)


          

按AND條件查詢指定字段數據

            
#查詢cpu使用率大于等于10且內存使用率大于等于10的數據,字段只顯示did、ts、cpu、mem
dataSet=collection.find({"cpu":{"$gte":10},"mem":{"$gte":10}}, {"did":1,"ts":1,"cpu":1,"mem":1})
for item in dataSet:
  print(item)
#查詢cpu使用率等于0且內存使用率等于0的數據,字段只顯示did、ts、cpu、mem
dataSet=collection.find({"cpu":0,"mem":0}, {"did":1,"ts":1,"cpu":1,"mem":1})
for item in dataSet:
  print(item)


          

按OR條件查詢指定字段數據

            
#查詢cpu使用率大于等于10或者內存使用率大于等于10的數據,字段只顯示did、ts、cpu、mem
dataSet=collection.find({"$or":[{"cpu":{"$gte":10}},{"mem":{"$gte":10}}]}, {"did":1,"ts":1,"cpu":1,"mem":1})
for item in dataSet:
  print(item)
#查詢cpu使用率等于10或者內存使用率等于10的數據,字段只顯示did、ts、cpu、mem
dataSet=collection.find({"$or":[{"cpu":10},{"mem":10}]}, {"did":1,"ts":1,"cpu":1,"mem":1})
for item in dataSet:
  print(item)


          

mongodb的條件操作符

            
#  > - $gt
#  < - $lt
#  >= - $gte
#  <= - $lte


          

排序

            
#單列升序排序查詢,,1 為升序,-1為降序
dataSet=collection.find().sort([("cpu",1)])
for item in dataSet:
  print(item)
#多列排序查詢
dataSet=collection.find().sort([('did',pymongo.ASCENDING),('cpu',pymongo.DESCENDING)])
for item in dataSet:
  print(item)


          

查詢結果寫入excel

            
#查詢cpu使用率大于等于10且內存使用率大于等于10的數據,字段只顯示did、ts、cpu、mem,查詢結果寫入excel
import pandas as pd
dataSet=collection.find({"cpu":{"$gte":10},"mem":{"$gte":10}}, {"did":1,"ts":1,"cpu":1,"mem":1})
did,ts,cpu,mem=[],[],[],[]
for item in dataSet:
  did.append(item["did"])
  ts.append(item["ts"])
  cpu.append(item["cpu"])
  mem.append(item["mem"])
df=pd.DataFrame({"did":did,"ts":ts,"cpu":cpu,"mem":mem})
df.to_excel("C:/Users/Desktop/設備cpu內存數據.xlsx")


          

跳行查詢

            
#下面表示跳過兩條數據后讀取數據
dataSet=collection.find().skip(2)
for item in dataSet:
  print(item)


          

去重

            
#查詢cpu使用率大于20、did不重復的數據
dataSet=collection.distinct("did",{"cpu":{$gt:20}})
for item in dataSet:
  print(item)
#等同mysql的select distinct(did) from user where cpu>20


          

參考:

操作mongodb更詳細說明https://www.jb51.net/article/169726.htm

更多關于Python相關內容感興趣的讀者可查看本站專題:《Python常見數據庫操作技巧匯總》、《Python數學運算技巧總結》、《Python數據結構與算法教程》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總》

希望本文所述對大家Python程序設計有所幫助。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論