mongodb數(shù)據(jù)庫實(shí)驗(yàn)之增刪查改
mongodb 數(shù)據(jù)庫實(shí)驗(yàn)
一:增加數(shù)據(jù)
操作1:單條插入:Yelp數(shù)據(jù)庫中的User數(shù)據(jù)集插入符和如下要求的數(shù)據(jù)
_id:自定義為自己的班級(jí);
user_id:自己的學(xué)號(hào)+任意字符(多于22個(gè)字符取前22位,不足22個(gè)字符補(bǔ)充字母,數(shù)字或下劃線);
name:姓名拼音;
review_count:任意隨機(jī)數(shù);
yelping_since:實(shí)驗(yàn)時(shí)間;
操作2:多條插入:
隨機(jī)構(gòu)建4條User數(shù)據(jù),有序插入U(xiǎn)ser數(shù)據(jù)集中;
db.user.insert( { _id: 2018211, user_id: 201821057900000000000000000000000, name: "xiao", review_count: 100, "yelping_since": ISODate("2020-11-17 07:58:51"), } )
the result
2: 插入多項(xiàng)數(shù)據(jù):
db.user.insertMany( [ { _id: 201821112, user_id: 201811111111111111111111, name: "xiaoxiao", review_count: 1, "yelping_since": ISODate("2020-11-18 07:58:51"), }, { _id: 201821114, user_id: 201822222222222222222, name: "xuexiao", review_count: 344, "yelping_since": ISODate("2030-11-18 07:58:51"), }, { _id: 201821117, user_id: 201833333333333333333, name: "xiaoxiao", review_count: 56, "yelping_since": ISODate("2020-11-19 07:58:51"), },] )
the result
二:刪除數(shù)據(jù)
刪除指定條件的數(shù)據(jù):刪除business數(shù)據(jù)集中 stars小于3且city位于Las Vegas的記錄;
db.business.remove({ "city": "Las Vegas", stars: { $lt:3 } })
result :
三: 更新數(shù)據(jù)
整體更新:將1.1中插入的數(shù)據(jù)整體更新
user_id:自己的班級(jí)+任意字符(多于22個(gè)字符取前22位,不足22個(gè)字符補(bǔ)充字母,數(shù)字或下劃線);
name:姓名拼音倒序;
review_count:任意隨機(jī)數(shù)(與之前不同);
yelping_since:當(dāng)前實(shí)驗(yàn)時(shí)間(與之前不同);
操作5:局部更新
將business數(shù)據(jù)集內(nèi)business_id為"8mIrX_LrOnAqWsB5JrOojQ"的記錄對(duì)應(yīng)的stars增加0.5
db.user.update({_id: 2018211125}, {name:"xiaoxiao", review_count: 0,yelping_since: ISODate("2020-11-18 21:58:51")})
result: 查詢后
部分更新
初始:
db.business.update({business_id:8mIrX_LrOnAqWsB5JrOojQ}, { "$inc":{stars:0.5} } )
進(jìn)行部分更新, 再次查詢結(jié)果為:
四:查詢
1: 查詢business集合內(nèi)latitude大于30,longitude小于50,state位于AZ的10條記錄
查詢business集合內(nèi)city為"Charlotte"或"Toronto"或“Scottsdale”的記錄(跳過前510條數(shù)據(jù))
db.business.find({ latitude: { "$gte": 30, "$lte": 50 }, state: "AZ" }).limit(10)
result:
查詢business集合內(nèi)city為"Charlotte"或"Toronto"或“Scottsdale”的記錄(跳過前510條數(shù)據(jù))
db.business.find({ city: { "$in": ["Charlotte", "Toronto", "cottsdale"] } }).skip(150)
result :
五索引:
創(chuàng)建索引:friend數(shù)據(jù)集上,建立user_id(升序)與friend_id(降序)多字段唯一索引
db.friend.createIndex({user_id:1 ,friend_id: -1})
result
查看索引:
db.friend.getIndexes()
六聚合:
統(tǒng)計(jì)review數(shù)據(jù)集中stars大于2.0對(duì)應(yīng)的不同user_id(作為_id)的stars評(píng)分總和(重命名為starSum)
db.review.aggregate([ { $match: { "stars": { "$gte": 2.0 } } }, { $group: { _id: "$user_id", starSum:{ $sum: "$stars" } } }, ])
result :
統(tǒng)計(jì)friend數(shù)據(jù)集中friend_id為"BI4jBJVto2tEQ0NiaR0rNQ"的不同用戶的總數(shù)(count)從第10條開始統(tǒng)計(jì)
db.friend.aggregate([ { $match: { friend_id:"BI4jBJVto2tEQ0NiaR0rNQ" } }, { $group: { _id: "$friend_id", Sum:{ $sum: "$count", } } }, ]).skip(10)
result :
統(tǒng)計(jì)friend數(shù)據(jù)集中不同的friend_id(distinct)
db.friend.distinct( "friend_id" )
result :
總結(jié)
到此這篇關(guān)于mongodb數(shù)據(jù)庫實(shí)驗(yàn)之增刪查改的文章就介紹到這了,更多相關(guān)mongodb增刪查改 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MongoDB設(shè)置登錄賬號(hào)、密碼及權(quán)限的詳細(xì)過程
這篇文章主要給大家介紹了關(guān)于MongoDB設(shè)置登錄賬號(hào)、密碼及權(quán)限的詳細(xì)過程,文中通過代碼以及圖文介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MongoDB具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09使用Node操作MongoDB數(shù)據(jù)庫的方法
這篇文章主要介紹了使用Node操作MongoDB數(shù)據(jù)庫的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-01-01MongoDB中的push操作詳解(將文檔插入到數(shù)組)
$push操作符添加指定的值到數(shù)組中,下面這篇文章主要給大家介紹了關(guān)于MongoDB中push操作(將文檔插入到數(shù)組)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11MongoDB數(shù)據(jù)庫兩階段提交實(shí)現(xiàn)事務(wù)的方法詳解
這篇文章主要介紹了MongoDB數(shù)據(jù)庫兩階段提交實(shí)現(xiàn)事務(wù)的方法,結(jié)合實(shí)例形式詳細(xì)分析了MongoDB數(shù)據(jù)庫事務(wù)提交、回滾、撤銷等操作的原理、實(shí)現(xiàn)方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2018-08-08Mongodb實(shí)現(xiàn)的關(guān)聯(lián)表查詢功能【population方法】
這篇文章主要介紹了Mongodb實(shí)現(xiàn)的關(guān)聯(lián)表查詢功能,結(jié)合實(shí)例形式較為詳細(xì)的分析了population方法實(shí)現(xiàn)關(guān)聯(lián)表查詢的原理與相關(guān)操作技巧,需要的朋友可以參考下2017-07-07MongoDB數(shù)據(jù)庫設(shè)置賬號(hào)密碼完整步驟
MongoDB這工具很好用的,頁面美觀,設(shè)置賬號(hào)密碼也必不可少,下面這篇文章主要給大家介紹了關(guān)于MongoDB數(shù)據(jù)庫設(shè)置賬號(hào)密碼的完整步驟,文中給出了詳細(xì)的實(shí)例代碼,需要的朋友可以參考下2023-05-05Mongodb億級(jí)數(shù)據(jù)性能測試和壓測
MongoDB是一個(gè)開源的、基于分布式文件存儲(chǔ)的NoSQL數(shù)據(jù)庫系統(tǒng),它使用文檔存儲(chǔ)方式,數(shù)據(jù)結(jié)構(gòu)由鍵值(key-value)對(duì)組成,本文給大家介紹了Mongodb億級(jí)數(shù)據(jù)性能測試和壓測,需要的朋友可以參考下2024-06-06