1.查看帮助命令
help
db.yourColl.help();
db.youColl.find().help();
db.help():显示数据库操作命令,里面有很多的命令
db.foo.help():显示集合操作命令,同样有很多的命令,foo指的是当前数据库下,一个叫foo的集合,并非真正意义上的命令
rs.help();
2.查看数据库相关信息
show dbs:显示数据库列表
show collections:显示当前数据库中的集合(类似关系数据库中的表)
show users:显示用户
3.对集合的插入,查找
db.foo.insert({aa:11})
db.foo.find() 查找所有记录
db.foo.find( { a : 1 } ):对于当前数据库中的foo集合进行查找,条件是数据中有一个属性叫a,且a的值为1
4.切换数据库
use <db name>:切换当前数据库,这和MS-SQL里面的意思一样
如:如果你想创建一个“myTest”的数据库,先运行use myTest命令,之后就做一些操作(如:db.createCollection('user')),这样就可以创建一个名叫“myTest”的数据库。
5.删除数据库
db.dropDatabase();
6.从指定主机上克隆数据库
db.cloneDatabase(“127.0.0.1”); 将指定机器上的数据库的数据克隆到当前数据库
7.从指定的机器上复制指定数据库数据到某个数据库
db.copyDatabase("mydb", "myTest", "127.0.0.1");将本机的mydb的数据复制到myTest数据库中
8.修复当前数据库
db.repairDatabase();
9.查看当前使用的数据库
db.getName();
db和db.getName()方法是一样的效果,都可以查询当前使用的数据库
10.显示当前db状态
db.stats();
11.当前db版本
db.version(); //3.0.2
12、查看当前db的链接机器地址
db.getMongo();
Collection聚集集合相关操作
1、创建一个聚集集合(table)
db.createCollection(“collName”, {size: 20, capped: 5, max: 100});
2、得到指定名称的聚集集合(table)
db.getCollection("account"); //列出指定名字的集合,如:myTest.foo
3、得到当前db的所有聚集集合
db.getCollectionNames(); //列出所有聚集集合的名,如:["foo","user","stu"]
4、显示当前db所有聚集索引的状态
db.printCollectionStats(); //打印出所有集合的状态信息
用户操作
1.创建用户
use admin db.createUser( { user: "adminUserName", pwd: "userPassword", roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] } )
role:可用的角色有:"dbOwner","userAdminAnyDatabase","root","read","userAdmin"等
2.删除用户
use test db.system.users.remove({user:"test"}); 或者 db.dropUser("test")
db.removeUser("userName");
3.数据库认证、安全模式
db.auth("userName", "123123");
1. db.yourColl.help(); //查看可以操作集合的方法,命令
2. db.yourColl.count(); //当前集合的数据条数
3. db.userInfo.dataSize(); //数据空间大小
4. db db.userInfo.getDB(); //当前聚集集合所在的db
5. db.userInfo.stats(); //当前聚集的状态
6. db.userInfo.totalSize(); //聚集集合总大小
7. db.userInfo.storageSize(); //储存空间大小
8. db.userInfo.getShardVersion() //Shard版本信息
9. db.userInfo.renameCollection("users"); //将userInfo重命名为users
10.db.userInfo.drop(); //删除当前聚集集合
对聚集集合的数据查询
1. db.user.find() ; //默认查询20条
DBQuery.shellBatchSize= 50; //设置每页显示50条
如果还有数据没有显示完,可用键入“it”命令,迭代查询后续记录。
2. db.userInfo.distinct("name");
//相当于select distict name from userInfo;
3.db.userInfo.find({"age": 22}) //查询age作为key,值为22的记录,可以不加""
//相当于: select * from userInfo where age = 22;
4. db.userInfo.find({age: {$gt: 22}});
//相当于:select * from userInfo where age >22;
5. db.userInfo.find({age: {$lt: 22}});
//相当于:select * from userInfo where age <22;
//注:查询条件中,操作符和条件值放在一个对象中,如{age: {$lt: 22}};而在更新数据中,列名和数据放在一个对象中,如{$set : {name: "zhangshan"}},而or查询又比较特殊,它有点类似于更新操作
//如{$or: [{age: 22}, {age: 25}]},它这里给的是对象数组
6.db.userInfo.find({age: {$gte: 23, $lte: 26}});
//查询age >= 23 并且 age <= 26
7.db.userInfo.find({name: /mongo/});
//模糊查找,相当于'%%'
8.db.userInfo.find({name: /^mongo/});
//模糊查找,name的值必须是以mongo开头,相当于'mongo%'
//注:find()方法中的第一个对象是查询条件;第二个对象是指定显示的列名,1和true代表显示,0和false代表去除这一列,其余列全部显示,也就是说,如果指定name:false,那么就不能再指定显示其它列,如age:1,否则,将报错
9.db.userInfo.find({}, {name: 1, age: 1});
//相当于:select name, age from userInfo where age >25;
10.db.userInfo.find({name: 'zhangsan', age: 22});
//相当于:select * from userInfo where name = ‘zhangsan’ and age = ‘22’
11.db.userInfo.find().limit(5); //查询前5条数据
12.db.userInfo.find().skip(10); //skip()表示跳过,也就是说跳过前10条记录
13.db.userInfo.find().limit(10).skip(5); //从第5条记录后,查询出10条记录,可用于分页,limit是pageSize,skip是第几页*pageSize
14.db.userInfo.find({$or: [{age: 22}, {age: 25}]});
//相当于:select * from userInfo where age = 22 or age = 25;
15.db.userInfo.findOne(); //查询第一条数据
16.db.userInfo.find({age: {$gte: 25}}).count(); //统计记录条数
17.db.userInfo.find({sex: {$exists: true}}).count(); //统计存在sex列的记录数,可以同时指定多个存在的列
排序
1.升序:db.userInfo.find().sort({age: 1});
2.降序:db.userInfo.find().sort({age: -1});
注:排序这里只能使用1和-1.不能使用true和false
索引
1、创建索引
db.userInfo.ensureIndex({name: 1});
db.userInfo.ensureIndex({name: 1, ts: -1});
2、查询当前聚集集合所有索引
db.userInfo.getIndexes();
3、查看总索引记录大小
db.userInfo.totalIndexSize();
4、读取当前集合的所有index信息
db.users.reIndex();
5、删除指定索引
db.users.dropIndex("name_1");
6、删除所有索引索引
db.users.dropIndexes();
增、删、改
1.添加
db.users.save({name: ‘zhangsan’, age: 25, sex: true}); //可以随意添加列
db.users.insert({name:'22',age:22})
2.修改
db.users.update({age: 25}, {$set: {name: 'changeName'}}, false, true); //前面一个对象是查询条件,后面一个对象是要修改的列
db.users.update({name: 'Lisi'}, {$inc: {age: 50}}, false, true); //在原有的基础上增加
//相当于:update users set age = age + 50 where name = ‘Lisi’;
3.删除
db.users.remove({age: 132}); //删除age=132的记录
4.按条件删除(也就是先查出来,排好序再删除)
db.users.findAndModify({
query: {age: {$gte: 25}},
sort: {age: -1},
update: {$set: {name: 'a2'}, $inc: {age: 2}},
remove: true,
new : true
});
db.runCommand({ findandmodify : "users",
query: {age: {$gte: 25}},
sort: {age: -1},
update: {$set: {name: 'a2'}, $inc: {age: 2}},
remove: true
});
注:1.remove和update两个必须指定一个
2.不是对查询到的所有数据都更新或删除,而是对第一个记录更新或删除
3.若没有指定new:true,则返回修改前的对象,若指定了new:true,则返回修改后的对象
4.若为remove操作,则返回被删除的对象,不能指定new:true,否则,将报错。
5.若没有查询到数据,则返回null
语句块操作
注:语法类似c和javascript,java,区分大小写
1.打印输出语句
print("Hello World!");
2.将一个对象转换成json
tojson(new Object()) //打印一个空对象,不是null, 而是{}
tojson(new Object({name:"zhang",age:22})) // {"name":"zhang","age":22}
3.循环插入
for (var i = 0; i < 30; i++) {
db.users.save({name: "u_" + i, age: 22 + i, sex: i % 2});
};
4.遍历查询结果
1).游标
var cursor = db.users.find(); //游标
while (cursor.hasNext()) {
printjson(cursor.next());
}
注:游标,也可以当作数组来使用
例如:cursor[4];
获取数组的长度:cursor.length()或cursor.count()
for (var i = 0, len = c.length(); i < len; i++)
printjson(c[i]);
2).forEach循环
db.users.find().forEach(printjson);
forEach中必须传递一个函数来处理每条迭代的数据信息
向forEach()传递自定义函数
db.users.find({age:24}).forEach(function(x) {print(tojson(x));});
5.把游标转换成数组
var arr = db.users.find().toArray();
printjson(arr[2]);