1. 程式人生 > 資料庫 >mongodb資料庫實驗之增刪查改

mongodb資料庫實驗之增刪查改

mongodb 資料庫實驗

一:增加資料

操作1:單條插入:Yelp資料庫中的User資料集插入符和如下要求的資料

_id:自定義為自己的班級;

user_id:自己的學號+任意字元(多於22個字元取前22位,不足22個字元補充字母,數字或下劃線);

name:姓名拼音;

review_count:任意隨機數;

yelping_since:實驗時間;

操作2:多條插入:

隨機構建4條User資料,有序插入User資料集中;

db.user.insert(
 {
  _id: 2018211,user_id: 201821057900000000000000000000000,name: "xiao",review_count: 100,"yelping_since": ISODate("2020-11-17 07:58:51"),}
)

the result

mongodb資料庫實驗之增刪查改

2: 插入多項資料:

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,review_count: 56,"yelping_since": ISODate("2020-11-19 07:58:51"),]
  
)

the result

mongodb資料庫實驗之增刪查改

二:刪除資料

刪除指定條件的資料:刪除business資料集中 stars小於3且city位於Las Vegas的記錄;

db.business.remove({
 "city": "Las Vegas",stars: {
  $lt:3
 }
})

result :

mongodb資料庫實驗之增刪查改

三: 更新資料

整體更新:將1.1中插入的資料整體更新

user_id:自己的班級+任意字元(多於22個字元取前22位,不足22個字元補充字母,數字或下劃線);

name:姓名拼音倒序;

review_count:任意隨機數(與之前不同);

yelping_since:當前實驗時間(與之前不同);

操作5:區域性更新

​ 將business資料集內business_id為"8mIrX_LrOnAqWsB5JrOojQ"的記錄對應的stars增加0.5

db.user.update({_id: 2018211125},{name:"xiaoxiao",review_count: 0,yelping_since: ISODate("2020-11-18 21:58:51")})

mongodb資料庫實驗之增刪查改

result: 查詢後

部分更新

初始: mongodb資料庫實驗之增刪查改

db.business.update({business_id:8mIrX_LrOnAqWsB5JrOojQ},{ "$inc":{stars:0.5}
}
)

進行部分更新, 再次查詢結果為:

mongodb資料庫實驗之增刪查改

四:查詢

1: 查詢business集合內latitude大於30,longitude小於50,state位於AZ的10條記錄

查詢business集合內city為"Charlotte"或"Toronto"或“Scottsdale”的記錄(跳過前510條資料)

db.business.find({
 latitude: {
  "$gte": 30,"$lte": 50
 },state: "AZ"
}).limit(10)

result:

mongodb資料庫實驗之增刪查改

查詢business集合內city為"Charlotte"或"Toronto"或“Scottsdale”的記錄(跳過前510條資料)

db.business.find({
 city: {
  "$in": ["Charlotte","Toronto","cottsdale"]
 }
}).skip(150)

result :

mongodb資料庫實驗之增刪查改

五索引:

建立索引:friend資料集上,建立user_id(升序)與friend_id(降序)多欄位唯一索引

db.friend.createIndex({user_id:1,friend_id: -1})

result

mongodb資料庫實驗之增刪查改

檢視索引:

db.friend.getIndexes()

mongodb資料庫實驗之增刪查改

六聚合:

統計review資料集中stars大於2.0對應的不同user_id(作為_id)的stars評分總和(重新命名為starSum)

db.review.aggregate([
 {
  $match: {
    "stars": {
   "$gte": 2.0
   }
  }
 },{
  $group: {
   _id: "$user_id",starSum:{
    $sum: "$stars"
   }
  }
 },])

result :

mongodb資料庫實驗之增刪查改

統計friend資料集中friend_id為"BI4jBJVto2tEQ0NiaR0rNQ"的不同使用者的總數(count)從第10條開始統計

db.friend.aggregate([
 {
  $match: {
   friend_id:"BI4jBJVto2tEQ0NiaR0rNQ"
  }
 },{
  $group: {
   _id: "$friend_id",Sum:{
    $sum: "$count",}
  }
 },]).skip(10)

result :

mongodb資料庫實驗之增刪查改

統計friend資料集中不同的friend_id(distinct)

db.friend.distinct(
 "friend_id"
 )

result : mongodb資料庫實驗之增刪查改

總結

到此這篇關於mongodb資料庫實驗之增刪查改的文章就介紹到這了,更多相關mongodb增刪查改 內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!