mongodb入门命令
1: mongo入门命令
1.1: show dbs 查看当前的数据库
(admin是管理相关的,用户操作、安全配置等需要切换到该数据库下。local放其他数据库的信息。test自己随意。)
1.2 use databaseName 选库
1.2 show tables/collections 查看当前库下的collection(表)
db.help()查看帮助
1.3 如何创建库?
Mongodb的库是隐式创建,你可以use 一个不存在的库
然后在该库下创建collection,即可创建库
1.4 db.createCollection('collectionName')
创建collection
1.5 collection允许隐式创建
Db.collectionName.×××ert(document);
例子:
db.user.×××ert({name:'lisi',age:18})
WriteResult({ "nInserted" : 1 })
db.user.×××ert({name:'zhangsan',age:22,gender:'male'})
WriteResult({ "nInserted" : 1 })
db.user.×××ert({name:'tingting',age:20,gender:'female',bobby:['sleep','shopping']})
WriteResult({ "nInserted" : 1 })
db.user.find();
{ "_id" : ObjectId("5c8ce520a8f7096660e878a3"), "name" : "lisi", "age" : 18 }
{ "_id" : ObjectId("5c8ce53aa8f7096660e878a4"), "name" : "zhangsan", "age" : 22, "gender" : "male" }
{ "_id" : ObjectId("5c8ce669a8f7096660e878a5"), "name" : "tingting", "age" : 20, "gender" : "female", "bobby" : [ "sleep", "shopping" ] }
(当然可以自定义_id,但是......)
1.6 db.collectionName.drop() ,
删除collection
1.7 db.dropDatabase(); (删除当前所在的数据库)
删除database
//选择库
use testing_base;
//创建表
db.createCollection("the_table");
//单个插入数据
db.getCollection("the_table").×××ert({"name":"张三","age":16,"address":"长安街"});
//批量插入数据:
db.getCollection("the_table").×××ertMany([
{"name":"朱小二","age":20,"address":"北京"},
{"name":"张三疯","age":50,"address":"湖北"},
{"name":"慕容嘿嘿","age":30,"address":"河北"}
])
//查询全部
db.the_table.find();
db.getCollection("the_table").find();
//查询指定的
db.the_table.find({name:'我要改了他的名字'});
db.getCollection("the_table").find({"name":"张三","age":16});
//$gt:大于
//$gte:大于等于
//$lt:小于
//$lte:小于等于
//$ne:不等于
//大于等于
db.getCollection("the_table").find({"age":{"$gte":30}});
//大于等于20,小于等于30
db.getCollection("the_table").find({"age":{"$gte":20, "$lte":30}});
//查询"age"大于21 并小于等于24 ,且" name"不为"朱小二"的数据
db.getCollection("the_table").find({"age":{"$gt":21,"$lte":30},"name":{"$ne":"朱小二"}});
//db.getCollection('table_name').find(用于过滤记录的字典,用于限定字段的字典)
//无特定设置则_id默认会显示
//如果不考虑" id ",则限定字段的字典里面的值只可能全都是0 或全都是1,不可能l和0混用,一旦混用则M ongoDB 就会报错
//不查询字段address和age
db.getCollection("the_table").find({},{"address":0,"age":0});
//要求只返回name 字段和age 字段,则查询语句如下:
db.getCollection("the_table").find({},{"address":1,"age":1});
//count的用法
db.getCollection("the_table").find({"age":{"$gt":10}}).count();
//限定返回结果limit (limit(1)默认返回第一条)
db.getCollection("the_table").find().limit(1);
//对结果排序sort (字段的值为-l表示倒序,为l表示正序)
db.getCollection("the_table").find({"age":{"$gt":10}}).sort({"age":-1});
//更新操作
//• updateOne : 只更新第l 条满足要求的数据。
//• updateMany : 更新所有满足要求的数据。
//修改" name "为" 张三疯"的文档, 添加"dizhi"字段(没有就是添加),并把"age"宇段从"50"改为"123"
db.getCollection("the_table").updateMany({"name":"张三疯"},{"$set":{"dizhi":"武当","age":123}});
//删除数据(将find替换为delete/deleteMany)
//慎用删除功能,一般工程上会用逻辑删除,如在文档里加个del字段,为0表示删除,1未删除
//• "delete" (如果只删除第1 条满足要求的数据)
//• "deleteMany" (如果要删除所有满足要求的数据〉
//删除age为666的所有数据
db.getCollection("the_table").deleteMany({"age":666});
//数据去重
//db.getCollection('the_table').distinct('字段名',查询语句的第一个字典)
//distinct()可以接收两个参数:
//• 第1 个参数为字段名, 表示对哪一个字段进行去重。
//• 第2 个参数就是查询命令" find()"的第l 个参数。distinct命令的第2个参数可以省略。
db.getCollection("the_table").distinct("name"); //(返回的值是一个数组,是去重以后的值)
//对age大于10的记录的name字段去重
db.getCollection("the_table").distinct("name",{"age":{"$gt":10}});
//能否去重以后再带上其他字段呢? 答案是,但用" distinct() "命令不能实现