NoSQL——MongoDB基础使用;

MongoDB常用的命令(import!!!);

在这里插入图片描述

Help 查看帮助;
显示数据库列表 > show dbs ;
创建数据库 > use dbname;
显示数据库中的集合 show collections ;

  • 如果数据库不存在,则创建数据库dbname,否则切换到指定数据库dbname。创建的数据库并不在数据库的列表中,要显示它,我们需要向数据库dbname插入一些数据
    MongoDB 中默认的数据库为 test,如果你没有创建新的数据库,集合将存放在 test 数据库中。

增加数据;

  • db.web.save({“name”:“老李”}) 创建了名为web的集合,并新增了一条{“name”:“老李”} 的数据
  • db.web.insert({“name”:“ghost”, “age”:10}) 在web集合中插入一条新数据,如果没有web这个集合,mongodb会自动创建;

save()和insert()也存在着些许区别

  • 若新增的数据主键已经存在,insert()会不做操作并提示错误,而save() 则更改原来的内容为新内容。

_id是主键,主键是每条数据的唯一标识,不能重复,就像身份证是每个人唯一的编号一样。

存在数据:{ _id : ObjectId(“57e8d34b4764fb71d0a89caa”), " name " : " 老李"} , _id是主键;

insert({ _id : ObjectId(“57e8d34b4764fb71d0a89caa”), " name " : " 老王 }) 会提示错误;

在这里插入图片描述
save(ObjectId(“57e8d34b4764fb71d0a89caa”), " name " : " 老王 " }) 会把 “老李” 改为 “ 老王” ,有update的作用。

在这里插入图片描述

删除数据;

  1. 删除文档
  2. 删除集合
  3. 删除数据库
  • db.users.remove({}) 删除users集合下所有数据;
  • db.users.remove({“name”: “lecaf”}) 删除users集合下name=”lecaf”的数据;
  • db.users.drop()或db.runCommand({“drop”:“users”}) 删除集合users;
  • db.runCommand({“dropDatabase”: 1}) 删除当前数据库,注意 此处的1没加双引号。

查找数据;

  • db.users.find() 查找users集合中所有数据;
  • db.users.findOne() 查找users集合中的第一条数据;
  • db.users.find().pretty() 格式化查询到的数据;

修改数据;

  • db.web.update({“name”:“a1”}, {“age”:10}) 修改name=a1的数据为sex=1,第一个参数是查找条件,第二个参数是修改内容,主键不能修改,如图
    在这里插入图片描述

MongoDB高级命令;

条件查找;
  • 学习用命令的意义在于:我们做系统的时候,后端人员需要给前端开发人员提供数据,如果后端人员用可视化工具,只是他自己眼睛能看到,但是如果要把这些数据提供给前端,他需要用代码去查数据库,把查询的结果返回给前端。
  • 语法:db.collection.find({ “key” : value }) ;
    • 查找key=value的数据; hjhgjhghhhhh
  • 语法: db.collection.find({ “key” : { $gt: value } }) key > value;
    • 查找key大于value的的集合;
  • 语法:db.collection.find({ “key” : { $lt: value } }) key < value;
    • 查找key小于value的的集合;
  • 语法:db.collection.find({ “key” : { $gte: value } }) key >= value;
    • 查找key大于等于value的的集合;
  • 语法:db.collection.find({ “key” : { $lte: value } }) key <= value;
    • 查找key小于等于value的的集合;
  • 语法:db.collection.find({ “key” : { $gt: value1 , $lt: value2 } }) ;
    • 查找value1 < key <value2的集合;
  • 语法:db.collection.find({ “key” : { $ne: value } });
    • 查找key ≠ value的集合;
  • 语法:db.collection.find({ “key” : { $mod : [ 10 , 1 ] } });
    • 取模运算,条件相当于key % 10 == 1 即key除以10余数为1的;
  • 语法:db.collection.find({ “key” : { $in: [ 1, 2, 3 ] } });
    • 属于,条件相当于key等于[ 1, 2, 3 ]中任何一个;
  • 语法:db.collection.find({ “key” : { $nin: [ 1, 2, 3 ] } });
    • 不属于,条件相当于key的值不属于[ 1, 2, 3 ]中任何一个;
  • 语法:db.collection.find({ “key” : { $size: 1 } });
    • $size 数量、尺寸,条件相当于key对应的值的数量是1(值必须是数组);
  • 语法:db.collection.find({ “key” : { $exists : true|false } });
    • $exists 字段存在,true返回存在字段key的数据,false返回不存在字段key的数据;
  • 语法:db.collection.find({ $or : [{a : 1}, {b : 2} ] }) ;
    • 符合两个条件中任意一个的数据。$or语法表示或的意思。 (注意:MongoDB 1.5.3后版本可用),符合条件a=1的或者符合条件b=2的数据都会查询出来。

排序;

  • db.collection.find().sort({ “key1” : -1 ,“key2” : 1 });
    • 这里的1代表升序,-1代表降序
其他;
  • db.collection.find().limit(5) ;
    • 控制返回结果数量,如果参数是0,则没有约束,limit()将不起作用;
  • db.collection.find().skip(5) ;
    • 控制返回结果跳过多少数量,如果参数是0,则当作没有约束,skip()将不起作用,或者说跳过了0条;
  • db.collection.find().skip(5).limit(5);
    • 可用来做分页,跳过5条数据再取5条数据;
  • db.collection.find().count() ;
    • count()返回结果集的条数;
  • db.collection.find().skip(5).limit(5).count(true) ;
    • 在加入skip()和limit()这两个操作时,要获得实际返回的结果数,需要一个参数true,否则返回的是符合查询条件的结果总数;
模糊查询;

db.collection.find({“name”:/ab/});

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值