mongodb操作整理

docker 安装mongodb:

docker 进入mongodb:docker exec -it mongodb /bin/bash

一、基本指令:

1.显示当前的所有数据库

show dbs

show databases

 

2.进入到指定的数据库中

use 数据库名

数据库不存在时,在插入数据是创建;

 

3.查看当前所处的数据库

db

 

4.显示数据库中所有的集合

show collections

 

  1. 删除集合
    db.collection.drop()
  2. 删除数据库
    db.dropDatabase()

二、文档格式:

1.自动生成id

{“naem”:“张三”,age:13}

 

2.指定id

{_id:1,“naem”:“张三”,age:13}

 

3.复合文档

{naem:“张三”,age:13,book:[{bookname:“语文”},{bookname:“数学”},{bookname:“英语”}],dept:{deptname:“it部门”,deptNo:“AI10101”}}

 

三、插入操作:可插入一个或多个文档

collection:集合名称

  1. db.collection.insert(), db.collection.insert([obj,obj])

1.1 向集合中插入一个或多个文档;

//插入单条数据

db.cjy.insert({name:"小明",age:18,sex:0})

//插入多条数据

db.cjy.insert([{name:"小明",age:18,sex:0},{name:"小红",age:16,sex:1}])

 

1.2 当我们向集合中插入文档时,如果没有给文档指定id属性,则数据库会自动为文档添加id 该属性用来作为文档的唯一标识根据ObjectId()函数生成;

//自定义id

db.cjy.insert({_id:"自定义",name:"小阿狸",age:18,sex:0})

//查看效果

db.cjy.find();  //下面是查询结果集

{ "_id" : ObjectId("5c0633c845d3507af1da8070"), "name" : "小明", "age" : 18, "sex" : 0 }

{ "_id" : ObjectId("5c0633c845d3507af1da8071"), "name" : "小红", "age" : 16, "sex" : 1 }

{ "_id" : "自定义", "name" : "小阿狸", "age" : 18, "sex" : 0 }

 

1.3 _id 可以自己指定,如果指定了数据库就不会在添加了,但是也必须确保它的唯一性;(效果如上1.2)

 

  1. db.collection.insertOne(obj)
    插入一个文档对象

db.cjy.insertOne({name:"龙瞎",age:16,sex:1})

3. db.collection.insertMany([obj,obj])

插入多个文档对象

db.cjy.insertMany([{name:"奥巴马",age:33,sex:0},{name:"小黄毛",age:19,sex:0}]);

 

四、查询操作

  1. db.collection.find()
    1.1 find()用来查询集合中所有符合条件的文档,返回的是一个数组

db.cjy.find();

1.2 find()可以接收一个对象作为条件参数,相当于sql中的where后的条件

find({}) 表示查询集合中所有的文档

db.cjy.find({});

find{属性:值} 查询属性是指定值的文档

db.cjy.find({name:"小黄毛"});

2. db.collection.findOne()

用来查询集合中符合条件的第一个文档,findOne()返回的是一个文档对象

db.cjy.findOne();

db.cjy.findOne({});

db.cjy.findOne({name:"小黄毛"});

3.查询所有结果的数量

db.collection.find().count()

db.collection.find({}).count()

db.collection.find().length()

db.collection.find({}).length()

注意:db.collection.find(属性:值).length(),不会按照条件来查询统计量的,只会统计所有的数据量

 

练习:

创建数据库my_test:

//1.进入my_test数据库

use my_test

//2.向数据库的user集合中插入一个文档

db.users.insert({ username:"sunwukong"});

//3.查询user集合中的文档

db.users.find();

//4.向数据库的user集合中插入一个文档

db.users.insert({ username:"zhubajie"});

//5.查询数据库user集合中的文档

db.users.find();

//6.统计数据库user集合中的文档数量

db.users.find().count();

//7.查询数据库user集合中username为sunwukong的文档

db.users.find({username:"sunwukong"});

//8.向数据库user集合中的username为sunwukong的文档,添加一个address属性,属性值为huaguoshan

db.users.update({username:"sunwukong"},{$set:{address:"huaguoshan"}});

//9.使用{username:"tangseng"} 替换 username 为 zhubajie的文档

db.users.replaceOne({username:"zhubajie"},{username:"tangseng"});

//10.删除username为sunwukong的文档的address属性

db.users.update({username:"sunwukong"},{$unset:{address:1}});

//11.向username为sunwukong的文档中,添加一个hobby:{cities:["beijing","shanghai","shenzhen"] , movies:["sanguo","hero"]}

//MongoDB的文档的属性值也可以是一个文档,当一个文档的属性值是一个文档时,我们称这个文档叫做 内嵌文档db.users.update({username:"sunwukong"},{$set:{hobby:{cities:["beijing","shanghai","shenzhen"], movies:["sanguo","hero"]}}});

db.users.find();

//12.向username为tangseng的文档中,添加一个hobby:{movies:["A Chinese Odyssey","King of comedy"]}

db.users.update({username:"tangseng"},{$set:{hobby:{movies:["A Chinese Odyssey","King of comedy"]}}})

//13.查询喜欢电影hero的文档

//MongoDB支持直接通过内嵌文档的属性进行查询,如果要查询内嵌文档则可以通过.的形式来匹配

//如果要通过内嵌文档来对文档进行查询,此时属性名必须使用引号

db.users.find({'hobby.movies':"hero"});

//14.向tangseng中添加一个新的电影Interstellar

//$push 用于向数组中添加一个新的元素

//$addToSet 向数组中添加一个新元素 , 如果数组中已经存在了该元素,则不会添加db.users.update({username:"tangseng"},{$push:{"hobby.movies":"Interstellar"}});

db.users.update({username:"tangseng"},{$addToSet:{"hobby.movies":"Interstellar"}});

db.users.find();//15.删除喜欢beijing的用户db.users.remove({"hobby.cities":"beijing"});

//16.删除user集合

db.users.remove({});

db.users.drop();

show dbs;

//17.向numbers中插入20000条数据 7.2s

for(var i=1 ; i<=20000 ; i++){

db.numbers.insert({num:i});

}

db.numbers.find()

db.numbers.remove({});

//0.4s

//注意下面程序需要选择后 按F9执行光标所选中的区域,F6是不执行的

var arr = [];

for(var i=1 ; i<=20000 ; i++){

arr.push({num:i});

}

db.numbers.insert(arr);

//18.查询numbers中num为500的文档

db.numbers.find({num:500})

//19.查询numbers中num大于5000的文档

db.numbers.find({num:{$gt:500}});

db.numbers.find({num:{$eq:500}});

//20.查询numbers中num小于30的文档

db.numbers.find({num:{$lt:30}});

//21.查询numbers中num大于40小于50的文档

db.numbers.find({num:{$gt:40 , $lt:50}});

//22.查询numbers中num大于19996的文档

db.numbers.find({num:{$gt:19996}});

//23.查看numbers集合中的前10条数据

db.numbers.find({num:{$lte:10}});

//limit()设置显示数据的上限

db.numbers.find().limit(10);

//在开发时,我们绝对不会执行不带条件的查询

db.numbers.find();

//24.查看numbers集合中的第11条到20条数据

/*

分页 每页显示10条

1-10 0

11-20 10

21-30 20

。。。

skip((页码-1) * 每页显示的条数).limit(每页显示的条数);

skip()用于跳过指定数量的数据

MongoDB会自动调整skip和limit的位置

*/

db.numbers.find().skip(10).limit(10);

//25.查看numbers集合中的第21条到30条数据

db.numbers.find().skip(20).limit(10);

db.numbers.find().limit(10).skip(10);

//26.将dept和emp集合导入到数据库中

db.dept.find()

db.emp.find()

//27.查询工资小于2000的员工

db.emp.find({sal:{$lt:2000}});

//28.查询工资在1000-2000之间的员工

db.emp.find({sal:{$lt:2000 , $gt:1000}});

//29.查询工资小于1000或大于2500的员工

db.emp.find({$or:[{sal:{$lt:1000}} , {sal:{$gt:2500}}]});

//30.查询财务部的所有员工

//(depno)

var depno = db.dept.findOne({dname:"财务部"}).deptno;

db.emp.find({depno:depno});

//31.查询销售部的所有员工

var depno = db.dept.findOne({dname:"销售部"}).deptno;

db.emp.find({depno:depno});

//32.查询所有mgr为7698的所有员工

db.emp.find({mgr:7698})

//33.为所有薪资低于1000的员工增加工资400元

db.emp.updateMany({sal:{$lte:1000}} , {$inc:{sal:400}});

db.emp.find()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值