MongoDB常用操作总结

时间:2023-03-08 17:07:34
MongoDB常用操作总结
====================================MGDB的操作======================================

0.创建数据库时使用(use 数据库名)来创建,但如果use命令之后没有进行其它操作(如:给定list)直接退出,那么use命令执行出来的数据库将会从缓冲池中被清除,并没有真正    创建!;

1.use命令不但能声明创建数据库而且还能可以***切换数据库***;

2.删除一个数据库时需切换到该数据库后使用 db.dropDatabase();语句即可;

3.查询当前登录用户有多少个数据库则使用 show dbs 命令;

====================================MGDB的list操作======================================

5.查询当前数据库中有几个list使用 show collections  命令 ;

6.从一个数据库删除一个list的时候使用 db.list名.drop();

7.给数据库增加一个list(list中必须要有元素)时先切换到当前数据库后使用 db.list名.insert({name:"asd",age:"12"});语句即可;

====================================MGDB的list中的数据操作======================================

8.在list中插入一条数据使用 db.list名.insert({name:"asd",age:"12"});

  8.1-> 如果数据库中声明了一个特殊的list(如:d-d)要给这样的list插入数据需要使用 db.getCollection("list名").text.insert({...}); 命令,所以在命名上需要注意;

  8.2-> 可以使用for循环进行使用insert 进行批量数据插入;

  8.3-> 如果在向list插入数据的时候 自己命名了"_id"键并产生重复数据时,使用insert则会报错,使用save则会变为修改上条"_id"键相同的数据;

9.更新一条list数据的命令是 db.list名.update({name:"asd"},{$set:{name:"bbb"}});***$set:操作符属于局部更新如果不使用会造成其它键值对被清掉***

  9.1-> 批量更新使用 db.list名.update({查询器},{更新器},false,true); 命令第四个参数是批量的意思,否则只更新第一条记录;

  ==============================$更新器==============================

  9.2-> (db.list名.update({查询器},{$set:{...}},false,true);)$set更新器中的内容如果不存在这个键 则加上这个键值对;

  9.3-> db.list名.update({num:5},{$inc:{num:正整数或负整数}},false,true); 如为正整数则加上相应的数组,负整数则减去相应的数字;

  9.4-> db.list名.update({num:5},{$unset:{num:任意正整数}},false,true); 会将把num的键值对删除掉;

     ==============================$更新器针对list中值为数组的键值对数据==============================

     9.5.1-> db.list名.update({num:5},{$push:{books:"aa"}},false,true); 如果这个list中存在一条或几条带有books为键值为数组的键值对则该数组进行更新,没有则创建,如果键存在而值不是数组形式则会报错;

     9.5.2-> db.list名.update({num:5},{$pushAll:{books:["aa","bb"]}},false,true); 和上条同理只是批量更新;

     9.5.3-> db.list名.update({num:5},{$addToSet:{books:["aa"]}},false,true); 如果books中存在aa则更新插入否则不执行;

     9.5.4-> db.list名.update({num:5},{$pop:{books:-1}},false,true); 如果books:-1时从值数组中删除第一个值,若为books:1则从最后一个位置删除一个值;

     9.5.5-> db.list名.update({num:5},{$pull:{books:"a"}},false,true); 删除book中值为a的值;

     9.5.6-> db.list名.update({num:5},{$pull:{books:["a","b"]}},false,true); 批量删除book中值为a和b的值;

     9.5.7-> ***批量判断式的更新值数组操作***  db.list名.update({num:5},{$addToSet:{books:{$each:["a","b"]}}},false,true); 如果books中存在a或b就不填加,否则就添加到books中去;

10.删除一条list元素db.list名.remove({"name" : "gg"});

11.删除所有记录 使用db.list名.remove();时索引并不删除***如果数据量及其庞大的话使用db.list名.drop();效率比较高***;

12.如果数据存在就选择更新操作数据不存在就选择插入操作(insertOrupdate)使用  db.list名.update({查询器},{更新器},true);