Mongodb學習總結

来源:https://www.cnblogs.com/jasonblogrecord/archive/2020/04/02/Mongodb.html
-Advertisement-
Play Games

2020/4/2 Mongodb使用的是類似與json字元串的形式存儲數據 [ { key:value }, { key:value }, ] Mongodb使用了不存在的對象,即創建該對象 use db 使用db資料庫 show dbs 查看當前伺服器中寫在磁碟上的資料庫 show tables ...


2020/4/2
Mongodb使用的是類似與json字元串的形式存儲數據
[
{
key:value
},
{
key:value
},
]

Mongodb使用了不存在的對象,即創建該對象

use db 使用db資料庫
show dbs 查看當前伺服器中寫在磁碟上的資料庫
show tables 查看資料庫中的collection
db 查看當前使用的資料庫

1.增刪改查:
增:
db.collection.insert({數據}) 自動生成 _id : ObjectId("")
官方推薦:
db.collection.insertOne({數據}) 插入一條數據
db.collection.insertMany([{數據},{數據}]) 插入多條數據
查:
db.collection.find({條件})
db.collection.findOne({條件})
改:
db.collection.update({條件},{$修改器:{數據}})
官方推薦:
db.collection.updateOne({條件},{$修改器:{數據}}) 更新一條數據
db.collection.updateMany({條件},{$修改器:{數據}}) 更新所有數據
刪:
db.collection.remove({條件})
官方推薦:
db.collection.deleteOne({條件}) 刪除一條數據
db.collection.deleteMany({條件}) 刪除所有符合條件的數據

清除collection:
db.collection.drop()

2.$關鍵字
數學比較符:
$lt
$lte
$gt
$gte
$eq :
db.collection.find("score":{$gt:80})
查詢關鍵字:
$or db.collection.find({$or:[{name:1},{age:73}]})
$in db.collection.find({age:{$in:[1,2,3,4]}}) #符合其中一個條件即可
$all db.collection.find({hobby:{$all:[1,2,3,4]}}) #子集查詢

2018年12月25日:
1.$修改器 :
$set 簡單粗暴 {name:value} dict["name"]=value

$unset 簡單粗暴的刪除欄位 {$unset:{name:1}} del dict["name"]
db.user_info.updateOne({age:200},{$unset:{age:1}})

$inc 引用增加
db.user_info.updateMany({},{$inc:{age:1}})

array操作
$push 在array中追加一個新的元素 [].append(item)
db.user_info.updateOne({name:"200wansui"},{$push:{hobby:10}})

$pull 在array中刪除一個的元素 [].remove(item) [].pop(-1)
db.user_info.updateOne({name:"200wansui"},{$pull:{hobby:0}})

$pop 不含索引 -1 從前往後  1 從後往前
db.user_info.updateOne({name:"200wansui"},{$pop:{hobby:1}})

2.$ 字元
db.user_info.updateOne({hobby:6},{$set:{"hobby.$":"六"}})
保存符合索引條件數據的下標

3.Object 字典操作
db.user_info.updateOne({name:"200wansui"},{$inc:{"info.tizhong":-5}})
db.user_info.updateOne({name:"200wansui"},{$set:{"info.long":12.5}})

4.array + Object
db.user_info.updateOne({"hobby.shengao":150},{$set:{"hobby.$.long":14}})

5.limit
db.user_info.find({}).limit(5)
選取數據從當前位置選擇5個

6.skip 跳過
db.user_info.find({}).skip(2)
從0開始跳過2條數據為當前位置

7.sort
db.user_info.find({}).sort({ id:-1 })
根據ID進行排序 -1倒敘 1正序

8.limit+skip+sort
db.user_info.find({}).limit(5).skip(10)
db.user_info.find({}).limit(c).skip((p-1)*c)

db.user_info.find({}).limit(5).skip(5).sort({ id:-1 })

優先順序最高的是 sort 
其次優先為 skip
最低優先順序 limit

9.pymongo
import pymongo
from bson import ObjectId

mongo_client = pymongo.MongoClient(host="127.0.0.1",port=27017)
MONGO = mongo_client["資料庫"]

查詢數據
res = list(MONGO.user_info.find({}))
print(res)

res = MONGO.user_info.find_one({"id":20})
res["_id"] = str(res["_id"])

res = list(MONGO.user_info.find({"$or":[{"name":"dwb"},{"id":15}]}))
print(res)

ObjectId json操作
res_obj = MONGO.user_info.find_one({"_id":ObjectId(res["_id"])})
print(res_obj)
print(res.get("name"),type(res.get("_id")),type(res))

import json
res_json = json.dumps(res)
print(res_json)

增加數據
res = MONGO.user_info.insert_one({"name":"pymongo","age":666})
print(res,res.inserted_id)

res = MONGO.user_info.insert_many([{"name":"pymongo","age":666},{"name":"pymongo","age":666}])
print(res,res.inserted_ids)

for doc in res:
print(doc)

修改數據
res = MONGO.user_info.update_many({"age":666},{"$set":{"name":"pydwb","age":999}})
print(res,dir(res),res.raw_result)

刪除數據
res = MONGO.user_info.delete_one({"id":20})
res = MONGO.user_info.delete_many({"name":1})
print(res,dir(res),res.raw_result)

skip sort limit

res = list(MONGO.user_info.find({}).limit(5))
print(len(res))

res = list(MONGO.user_info.find({}).limit(5).skip(5))
print(len(res),res)

res = list(MONGO.user_info.find({}).sort("age",pymongo.DESCENDING))
print(res)

res = list(MONGO.user_info.find({}).sort("age",pymongo.DESCENDING).skip(5).limit(2))
print(res)

python 的 update
res = MONGO.user_info.find_one({"name":"200wansui"})
print(res)
res.get("info")["shengao"] = 170
res.get("info")["tizhong"] = 130
res.get("info")["long"] = 18.5

MONGO.user_info.update_one({"_id":res.get("_id")},{"$set":res})
res = MONGO.user_info.find_one({"name":"200wansui"})
print(res)


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前提:先在centos7中安裝好了VMware Tools 安裝gcc: yum -y install gcc 安裝kernel-devel: yum -y install kernel-devel 設置好共用目錄: 點擊添加之後選擇共用目錄 在centos7終端命令中輸入 vmware-hgfsc ...
  • 最近的項目要求配置共用存儲的四節點集群,使集群能夠形成負載均衡。 但是大家知道,PostgreSQL不支持使用同一數據目錄生成多個實例,在執行pg_ctl start的時候,如果指定的數據目錄有實例在運行,則該實例會發生錯誤導致資料庫down掉。故而,我們選擇了基於pgpool-II + repmg ...
  • SQL Server中鎖機制保證併發情況下的數據訪問,開發過程中利用好索引減少數據,能減少數據掃描數據加鎖的過程,合理規範使用事務,能減少死鎖發生 ...
  • 1、鎖監控 查看鎖住的表: select request_session_id spid,OBJECT_NAME(resource_associated_entity_id) tableName from sys.dm_tran_locks where resource_type='OBJECT' ...
  • 參考資料:C語言中文網 存儲引擎: 資料庫存儲引擎是資料庫底層軟體組件,資料庫管理系統使用數據引擎進行創建、查詢、更新和刪除數據操作。 不同的存儲引擎提供不同的存儲機制、索引技巧、鎖定水平等功能,使用不同的存儲引擎還可以獲得特定的功能。 註:InnoDB 事務型資料庫的首選引擎,支持事務安全表(AC ...
  • 大體來說,MySQL 可以分為 Server 層和存儲引擎層兩部分。 select * from T where ID=10; 這條查詢語句的執行過程: 外部層: 用戶與server層交互的媒介 一.客戶端【用於連接資料庫,輸入命令/語句】 界面化連接資料庫 輸入 select * from T w ...
  • 什麼是事務 事務的概念 從業務層面上來說,事務就是一個最小的不可分割的單元,通常一個事務對應的是一個完整的業務(比如銀行的轉賬操作)。 為什麼要有事務 仍以銀行轉賬為例加以說明,比如我要從賬號A轉賬100元到賬號B,現在資料庫有一張表account,那麼就意味著需要同時執行兩條SQL語句的更新: 以 ...
  • 導讀 現代大部分的登錄系統都支持郵箱、手機號碼登錄兩種方式,那麼如何在郵箱或者手機號碼這個字元串上建立索引才能保證性能最佳呢? 今天這篇文章就來探討一下在Mysql中如何給一個字元串加索引才能達到性能最佳。 本文首發於作者的微信公眾號【碼猿技術專欄】,原創不易,喜歡的朋友支持一下,謝謝!!! 陳某將 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...