MongoDB练习

//1.进入my_test数据库

use my_test

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

db.users.insert({
    username:"clare"

});


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

db.users.find();


//4.向数据库的user集合中插入一个文档    
db.users.insert({
    username:"tung"

});   


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

db.users.find();


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

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


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

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


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

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


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

db.users.update({username:"clare"},{username:"tq"});


//10.删除username为tung的文档的address属性
db.users.update({username:"tung"},{$unset:{address:1}});

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

db.users.update({username:"tung"},{$set:{hobby:{cities:["beijing","shanghai","shenzhen"] , movies:["sanguo","hero"]}}});


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

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


//13.查询喜欢电影hero的文档
//MongoDB支持使用.来使用内嵌文档的属性,此时属性名必须使用引号

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


//14.向tq中添加一个新的电影Interstellar
//$push 向数组中添加一个元素
//$addToSet向数组中添加一个新元素:考虑不重复
db.users.update({username:"tq"},{$push:{"hobby.movies":"Interstellar"}});

db.users.find();


//15.删除喜欢beijing的用户

db.users.remove({"hobby.cities":"beijing"});


//16.删除users集合
db.users.remove({});

db.users.drop();


//17.向numbers中插入20000条数据
for(var i = 1; i <= 20000;i++){
    db.numbers.insert({num:i});//比较耗时
}
db.numbers.remove({});

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}});


//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条数据
//limit限制查询的上限

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


//24.查看numbers集合中的第11条到20条数据
//skip()跳过指定数量的数据

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


//25.查看numbers集合中的第21条到30条数据
//分页:skip((页码 - 1)*每页显示的条数).limit(每页显示的条数);两个函数位置不固定

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


//26.将dept和emp集合导入到数据库中
//在Collection上右击import Collections...
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.查询财务部的所有员工
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}});

//查询文档时,默认按照_id的值进行排列(升序)
//sort()可以用来指定文档的排序的规则,sort()需要传递一个对象来指定排序规则  1表示升序  -1表示降序
db.emp.find({}).sort({sal:1,empno:-1});

//在查询时,可以在第二个参数的位置来设置查询结果的投影
db.emp.find({},{ename:1,sal:1});

//文档之间的关系:
//一对一:内嵌文档
//一对多:相当于外键字段
//多对多:相当于外键字段为数组




你可能感兴趣的:(NoSql,MongoDB练习)