`
m635674608
  • 浏览: 4929944 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

MongoDB shell操作

 
阅读更多

  shell命令操作语法和JavaScript很类似,其实控制台底层的查询语句都是用JavaScript脚本完成操作的。使用shell 命令,需要启动mongo.exe。

        

常用shell命令如下:

       1、查询本地所有数据库名称        

 

> show dbs;

 

 

       2、切换至指定数据库环境(若无指定的数据库,则创建新的库

> use mydb;

       3、查询当前库下的所有聚集集合collection(相当于table)

> show collections;

       4、创建聚集集合

> db.createCollection('mycollection');

 

       5、查询聚集集合中数据条数

> db.mycollection.count();

           6、插入数据

 

> db.mycollection.insert({'username':'xyz_lmn','age':26,'salary':120});

 

 

往'mycollection'聚集集合中插上一条数库,name为'xyz_lmn',age为'26',salary为'120'

 

       7、查询age等于26的数据

> db.mycollection.find({"age":26});

       8、查询salary大于100的数据

> db.mycollection.find({salary:{$gt:100}});

      9、查询age小于30,salary大于100的数据

> db.mycollection.find({age:{$lt:30}},{salary:{$gt:100}});

     10、查询salary小于40或salary大于200的数据

> db.mycollection.find({$or: [{salary: {$lt:40}}, {salary: {$gt:200}}]});

     11、查询指定列的数据

> db.mycollection.find({},{age:1,salary:1});

1表示显示此列的意思,也可以用true表示
     12、查询username中包含'e'的数据

> db.mycollection.find({username:/e/});

      13、查询以a打头的数据

> db.mycollection.find({username:/^a/});

      14、查询age列数据,并去掉重复数据

> db.mycollection.distinct('age');

      15、查询前10条数据

> db.mycollection.find().limit(10);

      16、查询1条以后的所有数据

> db.mycollection.find().skip(1);

      17、查询第一条数据

> db.mycollection.findOne();

      18、查询结果集的记录数(查询salary小于40或大于100的记录数)

db.mycollection.find({$or: [{salary: {$lt:40}}, {salary: {$gt:100}}]}).count();

      19、按salary升序排序

> db.mycollection.find().sort({salary:1});

按照salary字段升序排序

      20、降序

> db.mycollection.find().sort({salary:-1});

按照salary字段降序排序

       21、根据username修改age

> db.employee.update({username:'jim'},{$set:{age:22}},false,true);

db.collection.update( criteria, objNew, upsert, multi )

criteria : update的查询条件,类似sql update查询内where后面的
objNew   : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
upsert   : 如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi    : mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。

       22、将指定username的age字段增加5

> db.mycollection.update({username:'jim'},{$inc:{age:5}},false,true);

将username为‘jim’的age字段加5
       23、删除username为'rose'的数据

> db.mycollection.remove({uname:'rose'});


       24、集合collection重命名

> db.mycollection.renameCollection('c_temp');

将mycollection集合重命名为'c_temp'

       25、删除集合

> db.c_temp.drop();

删除名为'c_temp'的集合

        26、删除当前数据库

> db.dropDatabase();

 

 

 

MongoDB是MongoDB自带的交互式Javascript shell,用来对MongoDB进行操作和管理的交互式环境。

  使用 "./mongo --help" 可查看相关连接参数,下面将从常见的操作,如插入,查询,修改,删除等几个方面阐述MongoDB shell的用法

  1、插入记录

> use my_mongodb
switched to db my_mongodb
> db.user.insert({uid:1,username:"Tom",age:25});
> db.user.insert({uid:2,username:"Jerry",age:25});
>

   本例向数据库my_mongodb的表user中插入了2条记录。MongoDB会隐式的创建数据库my_mongodb和表user,所以这个例子没有建库和建表的过程。

注:此处使用的是db.user,而不是mydb.user. 

可以通过show dbsshow collections来查看数据库及表,具体如下:

> show dbs
admin   (empty)
local   (empty)
my_mongodb      0.0625GB    ---隐式创建的数据库
> show collections
system.indexes
user                         ---隐式创建的表
>

  2、查询记录

  查询表中的全部记录:

>  db.user.find();
{ "_id" : ObjectId("4f81a49b779282ca68fd8a59"), "uid" : 1, "username" : "Tom", "age" : 25 }
{ "_id" : ObjectId("4f81a4a1779282ca68fd8a5a"), "uid" : 2, "username" : "Jerry", "age" : 25 }
>

   查询用户名是 ”Jerry” 记录:

> db.user.find({username:"Jerry"});
{ "_id" : ObjectId("4f81a4a1779282ca68fd8a5a"), "uid" : 2, "username" : "Jerry", "age" : 25 }
>

   3、修改记录

  将用户ID是2的记录的年龄修改为100:

> db.user.update({uid:2},{$set:{age:100}}) ;
>

   查询一下是否改过来了:

>  db.user.find({uid:2});
{ "_id" : ObjectId("4f81a4a1779282ca68fd8a5a"), "uid" : 2, "username" : "Jerry", "age" : 100 }
>

   4、删除记录

  将用户ID是1的记录从表user中删除:

> db.user.remove({uid:1});
> db.user.find(); 
{ "_id" : ObjectId("4f81a4a1779282ca68fd8a5a"), "uid" : 2, "username" : "Jerry", "age" : 100 }
>

   经验证,该记录确实被删除了。

  MongoDB Shell的用法丰富且简单易懂,详见:http://www.mongodb.org/display/DOCS/Tutorial       

MongoDB java客户端的用法详见:http://www.mongodb.org/display/DOCS/Java+Tutorial   

 

 

http://blog.csdn.net/xyz_lmn/article/details/8072621

 

http://suo.iteye.com/blog/1073324

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics