時間:2024-02-14 10:19作者:下載吧人氣:25
前言
Mongodb是一個非關系型數據庫軟件(NoSql),以類似json的形式bson存儲數據,bson有二進制的json的意思,官方說bson的效率更高,很適合存儲類似于對象的數據,這里權當把自己學習的過程記錄下來。
關于MongoDB的安裝方法給大家推薦下面這幾篇文章:
1、Linux下安裝MongoDB的實現步驟
2、window下安裝配置mongodb的教程圖解
3、Mac中mongoDB的安裝與卸載步驟詳解
好了,下面開始本文的正文:
MongoDB:NoSQL數據庫
MongoDB中的重要指示點
1、MongoDB中的三要素
2、MongoDB中的數據存儲是以Bson的形式存儲的,Bson是二進制的json,所以看上去記錄的形式類似于json數據
3、MongoDB中集合中的數據不同于關系型數據庫中的數據,MongoDB中文檔結構可以不同,因此擴展性非常好
MongoDB的優點:易擴展、高性能、靈活的數據模型
MongoDB的缺點:數據重復存儲,占用空間大
MongoDB啟動
命令行(終端)啟動命令
查看幫助命令,默認端口,日志位置
mongod –help
ps ajx|grep mongod
mongodb客戶端
mongo –help
MongoDB的基礎命令
操作數據庫命令
查看當前的數據庫:db
查看所有的數據庫:show dbs /show databases
切換數據庫:use db_name刪除當前的數據庫:db.dropDatabase()
顯示當前數據庫狀態:db.stats()
當前數據庫版本:db.version()
查看當前數據庫的鏈接機器地址:db.getMongo()
操作集合的命令
不手動創建集合:
手動創建結合:
創建用戶:db.createUser({user:"laowang",pwd:"123456",roles:[{role:"userAdmin",db:"stu"}]})
db.createCollection(name,options)
db.createCollection("stu")
db.createCollection("sub", { capped : true, size : 10 } )
顯示當前所以用戶:show users
刪除用戶:db.removeUser("userName")
查看集合: show collections
刪除集合: db.集合名稱.drop()
mongo中的數據類型
Object ID: ⽂檔ID
String: 字符串, 最常⽤, 必須是有效的UTF-8
Boolean: 存儲⼀個布爾值, true或false
Integer: 整數可以是32位或64位, 這取決于服務器
Double: 存儲浮點值
Arrays: 數組或列表, 多個值存儲到⼀個鍵
Object: ⽤于嵌⼊式的⽂檔, 即⼀個值為⼀個⽂檔
Null: 存儲Null值
Timestamp: 時間戳, 表示從1970-1-1到現在的總秒數
Date: 存儲當前⽇期或時間的UNIX時間格式
注意事項:
創建⽇期語句如下 :參數的格式為YYYY-MM-DD每個⽂檔都有⼀個屬性, 為_id, 保證每個⽂檔的唯⼀性
new Date('2017-12-20')
可以⾃⼰去設置_id插⼊⽂檔,如果沒有提供, 那么MongoDB為每個⽂檔提供了⼀個獨特的_id, 類型: objectID
objectID是⼀個12字節的⼗六進制數(了解):
插入數據
db.集合名稱.insert(document)插⼊⽂檔時, 如果不指定_id參數, MongoDB會為⽂檔分配⼀個唯⼀的ObjectId類型的_id
db.stu.insert({name:'gj',gender:1})
db.stu.insert({_id:"20170101",name:'gj',gender:1})
插入單條指定為字典, 插入多條指定為列表
保存
db.集合名稱.save(document)
如果⽂檔的_id已經存在則修改, 如果⽂檔的_id不存在則添加
區別于: insert如果存在直接報錯
簡單查詢:
db.集合名稱.find()
更新
語法: db.集合名稱.update(<query> ,<update>,{multi: <boolean>})
舉例:注意:”multi update only works with $ operators” 更新全部,必須使用 $set
db.stu.update({name:'hr'},{name:'mnc'})
更新一條,沒有更新的字段會丟棄.db.stu.update({name:'hr'},{$set:{name:'hys'}})
更新一條db.stu.update({},{$set:{gender:0}},{multi:true})
更新全部刪除
語法: db.集合名稱.remove(<query>,{justOne: <boolean>})
總結:
本篇文章到此結束,如果您有相關技術方面疑問可以聯系我們技術人員遠程解決,感謝大家支持本站!
網友評論