湛江做网站定做价格,网站设计与运营第二次,wordpress媒体文档,手机网站开发企业1.查看帮助命令 help db.yourColl.help(); db.youColl.find().help(); db.help()#xff1a;显示数据库操作命令#xff0c;里面有很多的命令 db.foo.help()#xff1a;显示集合操作命令#xff0c;同样有很多的命令#xff0c;foo指的是当前数据库下#xff0c;一个叫f…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:可用的角色有dbOwneruserAdminAnyDatabaserootreaduserAdmin等 2.删除用户 use test
db.system.users.remove({user:test});
或者
db.dropUser(test)db.removeUser(userName); 3.数据库认证、安全模式 db.auth(userName, 123123); 其他 1、查询之前的错误信息 db.getPrevError(); 2、清除错误记录 db.resetError(); 对聚集集合的信息的查看相当于是对表的信息的查看 1. db.yourColl.help(); //查看可以操作集合的方法命令2. db.yourColl.count(); //当前集合的数据条数 3. db.userInfo.dataSize(); //数据空间大小4. db db.userInfo.getDB(); //当前聚集集合所在的db5. db.userInfo.stats(); //当前聚集的状态 6. db.userInfo.totalSize(); //聚集集合总大小7. db.userInfo.storageSize(); //储存空间大小8. db.userInfo.getShardVersion() //Shard版本信息9. db.userInfo.renameCollection(users); //将userInfo重命名为users10.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 267.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是pageSizeskip是第几页*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}); //删除age132的记录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]); 转载于:https://www.cnblogs.com/yangwenbin/p/4449495.html